I checked everywhere so I am hopefully not repeating a question.
I want to add a portable update feature to some C code I am writing. The program may not be in any specific location, and I would prefer to keep it to a single binary (No dynamic library loading)
Then after the update is complete, I want the program to be able to restart (not a loop, actually reload from the HDD)
Is there any way to do this in C on Linux?
If you know where the program is saved on disk, then you can
exec()the program:If you don’t know where the program is on disk, either use
execvp()to search for it on $PATH, or find out. On Linux, use the/procfile system — and/proc/self/exespecifically; it is a symlink to the executable, so you would need to usereadlink()to get the value. Beware:readlink()does not null terminate the string it reads.If you want, you can arrange to pass an argument which indicates to the new process that it is being restarted after update; the bare minimum argument list I provided can be as complex as you need (a list of the files currently open for edit, perhaps, or any other appropriate information and options).
Also, don’t forget to clean up before reexecuting — cleanly close any open files, for example. Remember, open file descriptors are inherited by the executed process (unless you mark them for closure on
execwithFD_CLOEXECorO_CLOEXEC), but the new process won’t know what they’re for unless you tell it (in the argument list) so it won’t be able to use them. They’ll just be cluttering up the process without helping in the least.