- Use XDG Download directory (#490950)
parent
421cb2a539
commit
f6b91e5129
@ -0,0 +1,138 @@
|
|||||||
|
Use the XDG download directory for downloads instead of
|
||||||
|
made-up unusally nonesixtent ~/Downloads (fall back to it
|
||||||
|
in case there's no XDG user dir configuration).
|
||||||
|
|
||||||
|
Lubomir Rintel <lkundrak@v3.sk>
|
||||||
|
|
||||||
|
diff -up transmission-1.51/libtransmission/platform.c.xdg-download-dir transmission-1.51/libtransmission/platform.c
|
||||||
|
--- transmission-1.51/libtransmission/platform.c.xdg-download-dir 2009-03-28 12:30:43.817212449 +0100
|
||||||
|
+++ transmission-1.51/libtransmission/platform.c 2009-03-28 12:31:39.752214378 +0100
|
||||||
|
@@ -443,15 +443,124 @@ tr_getDefaultConfigDir( const char * app
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
+/* This was stolen from gthumb, though it probably originates from
|
||||||
|
+ * xdg-user-dirs's xdg-user-dir-lookup.c. See:
|
||||||
|
+ * http://www.redhat.com/archives/fedora-devel-list/2007-March/msg00677.html
|
||||||
|
+ */
|
||||||
|
const char*
|
||||||
|
tr_getDefaultDownloadDir( void )
|
||||||
|
{
|
||||||
|
- static char * s = NULL;
|
||||||
|
+ static char * user_dir = NULL;
|
||||||
|
+ char type[] = "DOWNLOAD";
|
||||||
|
+ FILE * file;
|
||||||
|
+ char * home_dir, * config_home, * config_file;
|
||||||
|
+ char buffer[512];
|
||||||
|
+ char * p, * d;
|
||||||
|
+ int len;
|
||||||
|
+ int relative;
|
||||||
|
+
|
||||||
|
+ if( user_dir != NULL )
|
||||||
|
+ return user_dir;
|
||||||
|
+
|
||||||
|
+ home_dir = getenv( "HOME" );
|
||||||
|
+ if( home_dir == NULL )
|
||||||
|
+ return strdup("/tmp" );
|
||||||
|
|
||||||
|
- if( s == NULL )
|
||||||
|
- s = tr_buildPath( getHomeDir( ), "Downloads", NULL );
|
||||||
|
+ config_home = getenv( "XDG_CONFIG_HOME" );
|
||||||
|
+ if( config_home == NULL || config_home[0] == 0 )
|
||||||
|
+ {
|
||||||
|
+ config_file = malloc( strlen( home_dir ) + strlen( "/.config/user-dirs.dirs" ) + 1 );
|
||||||
|
+ strcpy( config_file, home_dir );
|
||||||
|
+ strcat( config_file, "/.config/user-dirs.dirs" );
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ config_file = malloc( strlen ( config_home ) + strlen( "/user-dirs.dirs" ) + 1 );
|
||||||
|
+ strcpy( config_file, config_home );
|
||||||
|
+ strcat( config_file, "/user-dirs.dirs" );
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- return s;
|
||||||
|
+ file = fopen( config_file, "r" );
|
||||||
|
+ free( config_file );
|
||||||
|
+ if( file == NULL )
|
||||||
|
+ goto error;
|
||||||
|
+
|
||||||
|
+ while( fgets( buffer, sizeof( buffer ), file ) )
|
||||||
|
+ {
|
||||||
|
+ /* Remove newline at end */
|
||||||
|
+ len = strlen( buffer );
|
||||||
|
+ if( len > 0 && buffer[len-1] == '\n' )
|
||||||
|
+ buffer[len-1] = 0;
|
||||||
|
+
|
||||||
|
+ p = buffer;
|
||||||
|
+ while( *p == ' ' || *p == '\t' )
|
||||||
|
+ p++;
|
||||||
|
+
|
||||||
|
+ if( strncmp( p, "XDG_", 4 ) != 0 )
|
||||||
|
+ continue;
|
||||||
|
+ p += 4;
|
||||||
|
+
|
||||||
|
+ if( strncmp(p, type, strlen (type )) != 0)
|
||||||
|
+ continue;
|
||||||
|
+ p += strlen( type );
|
||||||
|
+
|
||||||
|
+ if( strncmp(p, "_DIR", 4 ) != 0)
|
||||||
|
+ continue;
|
||||||
|
+ p += 4;
|
||||||
|
+
|
||||||
|
+ while( *p == ' ' || *p == '\t' )
|
||||||
|
+ p++;
|
||||||
|
+
|
||||||
|
+ if( *p != '=' )
|
||||||
|
+ continue;
|
||||||
|
+ p++;
|
||||||
|
+
|
||||||
|
+ while( *p == ' ' || *p == '\t' )
|
||||||
|
+ p++;
|
||||||
|
+
|
||||||
|
+ if( *p != '"' )
|
||||||
|
+ continue;
|
||||||
|
+ p++;
|
||||||
|
+
|
||||||
|
+ relative = 0;
|
||||||
|
+ if( strncmp(p, "$HOME/", 6 ) == 0)
|
||||||
|
+ {
|
||||||
|
+ p += 6;
|
||||||
|
+ relative = 1;
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ if( *p != '/' )
|
||||||
|
+ continue;
|
||||||
|
+
|
||||||
|
+ if( relative )
|
||||||
|
+ {
|
||||||
|
+ user_dir = malloc( strlen ( home_dir ) + 1 + strlen ( p ) + 1 );
|
||||||
|
+ strcpy( user_dir, home_dir );
|
||||||
|
+ strcat( user_dir, "/" );
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ user_dir = malloc( strlen ( p ) + 1 );
|
||||||
|
+ *user_dir = 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ d = user_dir + strlen( user_dir );
|
||||||
|
+ while( *p && *p != '"' )
|
||||||
|
+ {
|
||||||
|
+ if( ( *p == '\\' ) && ( *( p + 1 ) != 0 ))
|
||||||
|
+ p++;
|
||||||
|
+ *d++ = *p++;
|
||||||
|
+ }
|
||||||
|
+ *d = 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ fclose( file );
|
||||||
|
+
|
||||||
|
+error:
|
||||||
|
+ if( !user_dir )
|
||||||
|
+ user_dir = tr_buildPath( getHomeDir( ), "Downloads", NULL );
|
||||||
|
+
|
||||||
|
+ return user_dir;
|
||||||
|
}
|
||||||
|
|
||||||
|
/***
|
Loading…
Reference in new issue