void cmd_shell(int argc, char **argv) { char *e = 0; if(argc > 1) e = args_cat(argc, argv, 1); invoke_shell(e); free(e); }
void cmd_bookmark(int argc, char **argv) { struct option longopts[] = { {"save", optional_argument, 0, 's'}, {"edit", no_argument, 0, 'e'}, {"read", optional_argument, 0, 'r'}, {"delete", no_argument, 0, 'd'}, {"list", no_argument, 0, 'l'}, {"noupdate", no_argument, 0, 'u'}, {"help", no_argument, 0, 'h'}, {0, 0, 0, 0} }; int action = BM_BOOKMARK; int c; char *bmfile = 0; optind = 0; while((c=getopt_long(argc, argv, "s::er::dluh", longopts, 0)) != EOF) { switch(c) { case 's': action = BM_SAVE; free(bmfile); bmfile = xstrdup(optarg); break; case 'e': action = BM_EDIT; break; case 'r': action = BM_READ; free(bmfile); bmfile = xstrdup(optarg); break; case 'd': action = BM_DELETE; break; case 'l': action = BM_LIST; break; case 'u': action = BM_TOGGLE_NOUPDATE; break; case 'h': print_bookmark_syntax(); /* fall through */ default: return; } } if(action == BM_SAVE) { bookmark_save(bmfile); if(bmfile) printf(_("bookmarks saved in %s\n"), bmfile); else printf(_("bookmarks saved in %s/bookmarks\n"), gvWorkingDirectory); return; } if(action == BM_READ) { char *tmp = 0; int ret; list_clear(gvBookmarks); if(bmfile) ret = parse_rc(bmfile, true); else { if (asprintf(&tmp, "%s/bookmarks", gvWorkingDirectory) == -1) { fprintf(stderr, _("Failed to allocate memory.\n")); return; } ret = parse_rc(tmp, false); } if(ret != -1) printf(_("bookmarks read from %s\n"), bmfile ? bmfile : tmp); free(tmp); return; } if(action == BM_EDIT) { invoke_shell("%s %s/bookmarks", gvEditor, gvWorkingDirectory); return; } if(action == BM_LIST) { listitem *li; printf(_("%zu bookmarks present in memory\n"), list_numitem(gvBookmarks)); for(li = gvBookmarks->first; li; li=li->next) { url_t *u = (url_t *)li->data; /* note: all info not printed */ printf("%-20s", u->alias ? u->alias : u->hostname); printf("%s://%s@%s", u->protocol ? u->protocol : "ftp", u->username, u->hostname); if(u->directory) { char* sp = shortpath(u->directory, 30, 0); printf("/%s", sp); free(sp); } putchar('\n'); } return; } if(action == BM_DELETE) { int i; bool del_done = false; minargs(optind); for(i = optind; i < argc; i++) { listitem *li; while((li = list_search(gvBookmarks, (listsearchfunc)urlcmp_name, argv[i])) != 0) { url_t *u = (url_t *)li->data; printf(_("deleted bookmark %s\n"), u->alias ? u->alias : u->hostname); list_delitem(gvBookmarks, li); del_done = true; } } if(del_done) { bookmark_save(0); printf(_("bookmarks saved in %s/bookmarks\n"), gvWorkingDirectory); } return; } if(action == BM_TOGGLE_NOUPDATE) { int i; bool toggle_done = false; if(argc == optind) { listitem *li; need_connected(); need_loggedin(); li = list_search(gvBookmarks, (listsearchfunc)urlcmp_name, ftp->url->alias); if(li) { url_t *u = (url_t *)li->data; u->noupdate = !u->noupdate; printf(_("%s: noupdate: %s\n"), u->alias ? u->alias : u->hostname, u->noupdate ? _("yes") : _("no")); toggle_done = true; } ftp->url->noupdate = !ftp->url->noupdate; if(!toggle_done) printf(_("%s: noupdate: %s\n"), ftp->url->alias ? ftp->url->alias : ftp->url->hostname, ftp->url->noupdate ? _("yes") : _("no")); } for(i = optind; i < argc; i++) { listitem *li; li = list_search(gvBookmarks, (listsearchfunc)urlcmp_name, argv[i]); if(li) { url_t *u = (url_t *)li->data; u->noupdate = !u->noupdate; printf(_("%s: noupdate: %s\n"), u->alias ? u->alias : u->hostname, u->noupdate ? _("yes") : _("no")); toggle_done = true; } } if(toggle_done) { bookmark_save(0); printf(_("bookmarks saved in %s/bookmarks\n"), gvWorkingDirectory); } return; } maxargs(1); need_connected(); need_loggedin(); create_bookmark(argc > 1 ? argv[1] : 0); }