tweaks: rewrite the same file name into the lock file as the first time
It would be better if nano wrote the full filename into the lock file, because that would be clearer when Vim displays its warning, but... this is faster and will do for now. (Nano should simply also store the full filename in the openfile struct, so that get_full_path() needs to be called just once for each file.) This addresses https://savannah.gnu.org/bugs/?57713.master
parent
ee05daab92
commit
48df800db3
16
src/files.c
16
src/files.c
|
@ -142,19 +142,15 @@ void set_modified(void)
|
||||||
titlebar(NULL);
|
titlebar(NULL);
|
||||||
|
|
||||||
#ifndef NANO_TINY
|
#ifndef NANO_TINY
|
||||||
if (openfile->lock_filename != NULL) {
|
if (openfile->lock_filename != NULL)
|
||||||
char *fullname = get_full_path(openfile->filename);
|
write_lockfile(openfile->lock_filename, openfile->filename, TRUE);
|
||||||
|
|
||||||
write_lockfile(openfile->lock_filename, fullname, TRUE);
|
|
||||||
free(fullname);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef NANO_TINY
|
#ifndef NANO_TINY
|
||||||
/* Write a lockfile, under the given lockfilename. This ALWAYS annihilates
|
/* Write a lockfile, under the given lockfilename. This ALWAYS annihilates
|
||||||
* an existing version of that file. Return 1 on success, and 0 on failure. */
|
* an existing version of that file. Return 1 on success, and 0 on failure. */
|
||||||
int write_lockfile(const char *lockfilename, const char *origfilename, bool modified)
|
int write_lockfile(const char *lockfilename, const char *filename, bool modified)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_PWD_H
|
#ifdef HAVE_PWD_H
|
||||||
int cflags, fd;
|
int cflags, fd;
|
||||||
|
@ -240,10 +236,8 @@ int write_lockfile(const char *lockfilename, const char *origfilename, bool modi
|
||||||
lockdata[27] = mypid / (256 * 256 * 256);
|
lockdata[27] = mypid / (256 * 256 * 256);
|
||||||
strncpy(&lockdata[28], mypwuid->pw_name, 16);
|
strncpy(&lockdata[28], mypwuid->pw_name, 16);
|
||||||
strncpy(&lockdata[68], myhostname, 32);
|
strncpy(&lockdata[68], myhostname, 32);
|
||||||
if (origfilename != NULL)
|
strncpy(&lockdata[108], filename, 768);
|
||||||
strncpy(&lockdata[108], origfilename, 768);
|
lockdata[1007] = (modified) ? 0x55 : 0x00;
|
||||||
if (modified == TRUE)
|
|
||||||
lockdata[1007] = 0x55;
|
|
||||||
|
|
||||||
wroteamt = fwrite(lockdata, sizeof(char), LOCKSIZE, filestream);
|
wroteamt = fwrite(lockdata, sizeof(char), LOCKSIZE, filestream);
|
||||||
|
|
||||||
|
|
|
@ -305,7 +305,7 @@ bool outside_of_confinement(const char *currpath, bool allow_tabcomp);
|
||||||
#ifndef NANO_TINY
|
#ifndef NANO_TINY
|
||||||
void init_backup_dir(void);
|
void init_backup_dir(void);
|
||||||
int delete_lockfile(const char *lockfilename);
|
int delete_lockfile(const char *lockfilename);
|
||||||
int write_lockfile(const char *lockfilename, const char *origfilename, bool modified);
|
int write_lockfile(const char *lockfilename, const char *filename, bool modified);
|
||||||
#endif
|
#endif
|
||||||
int copy_file(FILE *inn, FILE *out, bool close_out);
|
int copy_file(FILE *inn, FILE *out, bool close_out);
|
||||||
bool write_file(const char *name, FILE *f_open, bool tmp,
|
bool write_file(const char *name, FILE *f_open, bool tmp,
|
||||||
|
|
Loading…
Reference in New Issue