Ticket #46 (closed enhancement: fixed)

Opened 16 years ago

Last modified 11 years ago

savannah: mcedit forgets POSIX newline at end of file

Reported by: div0 Owned by: angel_il
Priority: major Milestone: 4.7.0-pre4
Component: mcedit Version:
Keywords: Cc:
Blocked By: Blocking:
Branch state: merged Votes for changeset: committed-master

Description (last modified by ossi) (diff)

Original: http://savannah.gnu.org/bugs/?16452

Submitted by:Rudolf Polzer <div0>Submitted on:Thu 27 Apr 2006 07:27:54 AM UTC
Category:NoneSeverity:3 - Normal
Status:NonePrivacy:Public
Assigned to:NoneOpen/Closed:Open
Release:4.6.1Operating System:GNU/Hurd

Original submission:

When editing a file, mcedit does not put a newline character at the 
end of the file as required by POSIX and other standards.

I quote IEEE 1003.2-2001:

A file that contains characters organized into one or more lines. 
The lines do not contain NUL characters and none can exceed 
{LINE_MAX} bytes in length, including the <newline>.

I think a text editor should default to the OS's text file format 
which does require a newline at the end of the last line (many 
utilities including sudo actually require that and gcc warns if the 
last line does not end with a newline). Of course, if one is 
editing a DOS file (CRLF line separators), no newline is to be 
enforced.

Comment 1 by Oswald Buddenhagen <ossi> at Thu 27 Apr 2006 04:05:23 PM UTC:

nothing in the quoted paragraph suggests that a newline has to be 
present. there are two philosophies regarding newlines: newlines as 
line terminators (requires newline) and newlines as line breaks 
(separators - no newline required). personally, i also lean towards 
line termination. however, so far mcedit follows a "don't do 
anything not explicitly requested" philosophy (autoindent being the 
exception) - not necessarily by design, but because it is simpler 
to implement. but i'd argue that the "explicit" mode is a good 
default choice anyway.

as far as dos newlines are concerned, i repeatedly found it 
annoying that mcedit can't deal with them (displaying ^M does not 
count ;). i think it should handle them transparently - and 
possibly offer a conversion option.

Comment 2 by Rudolf Polzer <div0> at Thu 27 Apr 2006 09:47:52 PM UTC:

Sorry, I forgot to quote the definition of "line" too...

3.205 Line
A sequence of zero or more non-<newline>s plus a terminating <newline>.

http://www.opengroup.org/onlinepubs/000095399/basedefs/xbd_chap03.html

However, another solution would be using syntax highlighting to 
highlight a missing newline at the end of the file if it is known 
that a file format requires it (just like Makefiles are handled 
when a line starts with eight spaces).

And since many tools get quite irritated if the newline is missing 
(another prominent example is "cat" - people often wonder why the 
shell prompt gets in the same line as the file data - and then of 
course some old versions of vi and less that I've seen on some 
older UNIX systems), it would be good to at least highlight the 
missing newline even by default. 

Comment 3 by Rudolf Polzer <div0> at Thu 27 Apr 2006 09:50:09 PM UTC:

Damn, why does it say GNU/Hurd there? I'm quite sure that I didn't 
select that on purpose (I'm using GNU/Linux and FreeBSD), maybe I 
just clicked next to the right choice... please change that or 
ignore it, thanks.

Comment 4 by Roland Illig <rillig> at Sat 29 Apr 2006 08:12:29 AM UTC:

mcedit is currently suitable for editing binary files, too. I 
wouldn't like to give up this feature. So we had to do something 
like:

if (the current file looks like a text file) {
    if (edit->size > 0 && get_byte(edit->size) != '\n') {
        if (inputbox("This file does not end with a newline. "
                     "Shall we add it?", YES | NO | CANCEL) == YES) {
            edit_insert_byte(edit->size, '\n');
        }
    }
}

Comment 5 by Oswald Buddenhagen <ossi> at Sat 29 Apr 2006 08:25:21 AM UTC:

... except that this patch does not actually handle the Cancel case 
...
but other than that i'm fine with it.

Comment 6 by Rudolf Polzer <div0> at Sat 29 Apr 2006 09:18:23 AM UTC:

I think such a dialog box should rather read:

The file you are editing does not end with a newline as required by 
many programs. Do you want to add one?
[Yes] [No]

and - since mcedit is suitable for editing binaries - it would not 
hurt if "No" was the by default selected button.

But a method to warn the user via some red highlighting would also 
suffice I think... the main reason is that I often read about 
complaints from users who edited their files with mcedit - and then 
the program (again, sudo and gcc are the most prominent examples) 
fails to work with the file (sudo, and there is no indication in 
the error messages about what is wrong) or outputs a warning the
clueless user does not understand (in case of gcc - although I 
think gcc's warning is clear enough).

Comment 7 by Leonard den Ottolander <leonardjo> at Wed 21 Jun 2006 05:36:17 PM UTC:

Any patches forthcoming?

Change History

comment:1 Changed 16 years ago by styx

  • Milestone set to future releases

comment:2 Changed 15 years ago by angel_il

  • severity set to no branch
  • Milestone changed from future releases to 4.7.0-pre3

I think it can be optional

comment:3 Changed 15 years ago by angel_il

  • Status changed from new to accepted
  • Owner set to angel_il

comment:4 Changed 15 years ago by angel_il

  • Milestone changed from 4.7.0-pre3 to 4.7.0-pre4

comment:5 Changed 15 years ago by angel_il

  • severity changed from no branch to on review

branch: 46_POSIX_new_line (parent: master)
changeset: 251854c7a760a926757ce6ea2ea3afd88a69e044

comment:6 Changed 15 years ago by slavazanko

  • Votes for changeset set to slavazanko

comment:7 Changed 15 years ago by angel_il

comment:8 Changed 15 years ago by angel_il

comment:9 Changed 15 years ago by angel_il

comment:10 Changed 15 years ago by andrew_b

  • Votes for changeset changed from slavazanko to slavazanko andrew_b
  • severity changed from on review to approved

comment:11 Changed 15 years ago by angel_il

  • Status changed from accepted to testing
  • Votes for changeset changed from slavazanko andrew_b to commited-master
  • Resolution set to fixed
  • severity changed from approved to merged

comment:12 Changed 15 years ago by angel_il

  • Status changed from testing to closed

comment:13 Changed 11 years ago by ossi

  • Description modified (diff)
  • Branch state set to no branch
  • Reporter changed from slavazanko to div0

comment:14 Changed 11 years ago by andrew_b

  • Branch state changed from no branch to merged
Note: See TracTickets for help on using tickets.