Le 10.10.2013 21:59, Jerry Stuckle a écrit :
On 10/10/2013 3:08 PM, berenger.mo...@neutralite.org wrote:
Le 10.10.2013 20:20, Brad Rogers a écrit :
On Thu, 10 Oct 2013 10:54:57 -0700
Gregory Nowak <g...@gregn.net> wrote:
Hello Gregory,
"purge
purge is identical to remove except that packages are
removed and
purged (any configuration files are deleted too)."
As has been said, the man page is imprecise.
I wonder if that could justify a bug report? Speaking about that, I
have
no idea about what exactly does the reinstall option: simply remove
and
then install, or purge and then install? If, as I think, it's the
first
option, what is the use for that, since packages should not lose
files
magically?
I'm not sure what the confusion is here. Sure, it deletes all
configuration files it knows about. But then I would NOT expect it
to
delete any user-generated files, configuration or otherwise. I would
only expect it to delete what it can restore.
Jerry
Maybe you, since you know how it works. But, someone with no knowledge
would think that it also removes userland configuration files, since it
claims to remove all configuration files.
To be honest, sometimes I would really like it to be able to do so :)
and I could imagine ways to do that, too.
For example, imagine if all softwares would respect XDG Base Directory
Specification ( oh, wait, they won't, lennart participate ;) but
honestly, I really would like it to be followed ) to install
configuration files in $XDG_CONFIG_HOME. dpkg would simply have to check
for all users with a home directory what is their XDG_CONFIG_HOME and
search here the repertory to remove, in case of a purge. That does not
sounds so impossible, right?
Of course, there is the problem of determining where the hell that
variable is defined for each users, and it would also imply that all
softwares respect it, which will probably never happen.
But, in my opinion, having a tool able to remove configuration files
from user directories would help. A lot. Because it happens that I try
some softwares, and then purge them, but I still have to find every
single file they could have installed by hand. And this is *really*
boring.
I know that it would have it's own problems, of course, for example
when you install multiple versions of the same program, or if some users
want to keep their files anyway (this issue could be fixed by not
effectively removing those files, but by installing a script which would
ask to users if they want to keep or remove files, script which would be
automatically run at their next session ).
I know that it would not be so easy ( I can think about other problems
that I did not mention, but I do not want to write a novel ) , but it
would be doable, by someone with enough knowledge of package management
and global system, and, again, if most softwares were willing to respect
XDG specs. Vim, bash, xpaint, firefox, those are few examples of widely
known softwares, which does not respect that spec. And for which reason?
I guess there are none. And there are tons of other softwares which does
not.
My homedir is far more messy on Debian than on windows finally, and I
clean it frequently, but I use it far more often on Debian than on
Windows ( where the usages are more to use desktop, other partitions or
"my documents"). Don't you think that something is wrong, here?
The problem is not technical, because it's easy to do, even in C:
======
#define HOME_CONFIG "XDG_CONFIG_DIR" // can be used to keep windows
compatibility without changing any line of code
#define PROGRAM_OWN_CONFIG_DIR "/some/strange/config/dir/name/"
char* user_config_dir = getenv(HOME_CONFIG);
if( !user_config_dir )
exit( -1 );
unsigned short mcd_len = strlen( user_config_dir ) + strlen(
LEN_OF_PROGRAM_OWN_CONFIG_DIR ) +1;
char* my_config_dir = malloc( mcd_len );
if( !my_config_dir )
exit( -2 );
if( 0 == strlen( user_config_dir ) )
strncpy( my_config_dir, "~", 1 );
else
strncpy( my_config_dir, user_config_dir, strlen( user_config_dir ) );
strncat( my_config_dir + strlen( my_config_dir ),
PROGRAM_OWN_CONFIG_DIR, LEN_OF_PROGRAM_OWN_CONFIG_DIR );
======
That's portable, standard, written in less than 5min and relatively
secure ( there are still flaws there, but I am more used to C++, and
it's a simple demo ). So, why not doing it? Less than 20 lines in C,
less than 5 lines in C++, and probably not more in other languages.
--
To UNSUBSCRIBE, email to debian-user-requ...@lists.debian.org
with a subject of "unsubscribe". Trouble? Contact listmas...@lists.debian.org
Archive: http://lists.debian.org/e823575541db7233c2f9fe85c5b8d...@neutralite.org