} GuiContext;
int verbosity = 0;
+char **pmount_argv = NULL;
/**
Parses a string of the form name=value and places the components in a Property
*/
Property *get_device_properties(char *node)
{
+ static const char *udevadm_path = NULL;
int pid;
int pipe_fd[2];
char *buf;
Property *props = NULL;
int n_props = 0;
+ if(!udevadm_path)
+ {
+ struct stat st;
+ udevadm_path = "/bin/udevadm";
+ if(stat(udevadm_path, &st)<0 || !(st.st_mode&0111))
+ {
+ udevadm_path = "/sbin/udevadm";
+ if(stat(udevadm_path, &st)<0 || !(st.st_mode&0111))
+ {
+ udevadm_path = NULL;
+ perror("Unable to find udevadm");
+ return NULL;
+ }
+ }
+ }
+
pipe(pipe_fd);
pid = fork();
close(pipe_fd[0]);
dup2(pipe_fd[1], 1);
- execl("/sbin/udevadm", "udevadm", "info", "-q", "property", "-n", node, NULL);
+ if(execl(udevadm_path, "udevadm", "info", "-q", "property", "-n", node, NULL)<0)
+ fprintf(stderr, "Unable to execute %s: %s\n", udevadm_path, strerror(errno));
+
_exit(1);
}
else if(pid<0)
char **nodes = NULL;
Device *devices = NULL;
int n_devices = 0;
- char **mounted = NULL;
char **fstab = NULL;
int i;
{
if(verbosity>=2)
printf(" No properties\n");
+ free(nodes[i]);
continue;
}
}
free(nodes);
- free_string_array(mounted);
+ free_string_array(fstab);
if(devices)
{
if(pid==0)
{
/* Child process */
+
+ /* Complete construction of pmount call */
+ int last;
+
+ pmount_argv[0] = "pmount";
+
+ last = 0;
+ while(pmount_argv[++last]);
+
+ pmount_argv[last] = device->node;
+ pmount_argv[last+1] = mount_point+7;
+ pmount_argv[last+2] = NULL;
+
if(verbosity>=1)
{
if(umount)
printf("Running pumount %s\n", device->node);
else
- printf("Running pmount %s %s\n", device->node, mount_point+7);
+ {
+ int i = 0;
+ printf("Running pmount");
+ while(pmount_argv[++i])
+ printf(" %s", pmount_argv[i]);
+ printf("\n");
+ }
}
close(pipe_fd[0]);
if(umount)
execl("/usr/bin/pumount", "pumount", device->node, NULL);
else
- execl("/usr/bin/pmount", "pmount", device->node, mount_point+7, NULL);
+ execvp("/usr/bin/pmount", pmount_argv);
_exit(1);
}
else if(pid<0)
void show_help(void)
{
printf("pmount-gui\n"
- "Copyright (c) 2011-2015 Mikko Rasa, Mikkosoft Productions\n\n"
- "Usage: pmount-gui [-v] [-u] [-r <command>] [-m|-M] [-h]\n\n"
+ "Copyright (c) 2011-2016 Mikko Rasa, Mikkosoft Productions\n\n"
+ "Usage: pmount-gui [-v] [-u] [-r <command>] [-m|-M] [-h] [-- <pmount options>]\n\n"
"Options:\n"
" -v Increase verbosity\n"
" -u Unmount a device (default is mount)\n"
int opt;
int umount = 0;
int n_listed;
+ int i;
context.manager = 0;
context.autohide = 0;
return 0;
}
+ /* argc - optind equals to number of options after "--" */
+ /* One empty element at the beginning is for program name for execvp */
+ /* Three empty elements at the end are required options for pmount + NULL */
+
+ pmount_argv = malloc(sizeof(char *)*(argc-optind+4));
+
+ for(i=0; i<(argc-optind); ++i)
+ pmount_argv[i+1] = argv[optind+i];
+ pmount_argv[argc-optind+1] = NULL;
+
context.window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
gtk_container_set_border_width(GTK_CONTAINER(context.window), 5);
g_signal_connect(context.window, "destroy", G_CALLBACK(>k_main_quit), NULL);
if(context.inotify_fd>=0)
close(context.inotify_fd);
+ free(pmount_argv);
+
return 0;
}