X-Git-Url: https://git.librecmc.org/?p=oweals%2Fopkg-lede.git;a=blobdiff_plain;f=src%2Fopkg-cl.c;h=5f66d28f7332c302232c5988b456695b7a36ba14;hp=ebaa3d063e9d851c788ff317adfa2835ffa1cfff;hb=ebecbc302f97b04c2b5bfedd00030d1cfd700607;hpb=6efa2657bf14266c58ae8c0c16d8584dac6ed600 diff --git a/src/opkg-cl.c b/src/opkg-cl.c index ebaa3d0..5f66d28 100644 --- a/src/opkg-cl.c +++ b/src/opkg-cl.c @@ -28,6 +28,7 @@ #include "opkg_cmd.h" #include "file_util.h" #include "opkg_message.h" +#include "opkg_download.h" #include "../libbb/libbb.h" enum { @@ -40,11 +41,13 @@ enum { ARGS_OPT_FORCE_REMOVAL_OF_ESSENTIAL_PACKAGES, ARGS_OPT_FORCE_SPACE, ARGS_OPT_FORCE_POSTINSTALL, + ARGS_OPT_FORCE_REMOVE, ARGS_OPT_ADD_ARCH, ARGS_OPT_ADD_DEST, ARGS_OPT_NOACTION, ARGS_OPT_DOWNLOAD_ONLY, ARGS_OPT_NODEPS, + ARGS_OPT_NOCASE, ARGS_OPT_AUTOREMOVE, ARGS_OPT_CACHE, }; @@ -79,9 +82,12 @@ static struct option long_options[] = { ARGS_OPT_FORCE_REMOVAL_OF_ESSENTIAL_PACKAGES}, {"force-postinstall", 0, 0, ARGS_OPT_FORCE_POSTINSTALL}, {"force_postinstall", 0, 0, ARGS_OPT_FORCE_POSTINSTALL}, + {"force-remove", 0, 0, ARGS_OPT_FORCE_REMOVE}, + {"force_remove", 0, 0, ARGS_OPT_FORCE_REMOVE}, {"noaction", 0, 0, ARGS_OPT_NOACTION}, {"download-only", 0, 0, ARGS_OPT_DOWNLOAD_ONLY}, {"nodeps", 0, 0, ARGS_OPT_NODEPS}, + {"nocase", 0, 0, ARGS_OPT_NOCASE}, {"offline", 1, 0, 'o'}, {"offline-root", 1, 0, 'o'}, {"add-arch", 1, 0, ARGS_OPT_ADD_ARCH}, @@ -103,7 +109,7 @@ args_parse(int argc, char *argv[]) char *tuple, *targ; while (1) { - c = getopt_long_only(argc, argv, "Ad:f:no:p:t:vV::", + c = getopt_long_only(argc, argv, "Ad:f:ino:p:t:vV::", long_options, &option_index); if (c == -1) break; @@ -118,6 +124,9 @@ args_parse(int argc, char *argv[]) case 'f': conf->conf_file = xstrdup(optarg); break; + case 'i': + conf->nocase = FNM_CASEFOLD; + break; case 'o': conf->offline_root = xstrdup(optarg); break; @@ -166,9 +175,15 @@ args_parse(int argc, char *argv[]) case ARGS_OPT_FORCE_POSTINSTALL: conf->force_postinstall = 1; break; + case ARGS_OPT_FORCE_REMOVE: + conf->force_remove = 1; + break; case ARGS_OPT_NODEPS: conf->nodeps = 1; break; + case ARGS_OPT_NOCASE: + conf->nocase = FNM_CASEFOLD; + break; case ARGS_OPT_ADD_ARCH: case ARGS_OPT_ADD_DEST: tuple = xstrdup(optarg); @@ -200,6 +215,9 @@ args_parse(int argc, char *argv[]) } } + if(!conf->conf_file && !conf->offline_root) + conf->conf_file = xstrdup("/etc/opkg.conf"); + if (parse_err) return parse_err; else @@ -214,7 +232,7 @@ usage() printf("\nPackage Manipulation:\n"); printf("\tupdate Update list of available packages\n"); - printf("\tupgrade Upgrade installed packages\n"); + printf("\tupgrade Upgrade packages\n"); printf("\tinstall Install package(s)\n"); printf("\tconfigure Configure unpacked package(s)\n"); printf("\tremove Remove package(s)\n"); @@ -225,16 +243,21 @@ usage() printf("\tlist List available packages\n"); printf("\tlist-installed List installed packages\n"); printf("\tlist-upgradable List installed and upgradable packages\n"); + printf("\tlist-changed-conffiles List user modified configuration files\n"); printf("\tfiles List files belonging to \n"); printf("\tsearch List package providing \n"); + printf("\tfind List packages whose name or description matches \n"); printf("\tinfo [pkg|regexp] Display all info for \n"); printf("\tstatus [pkg|regexp] Display all status for \n"); printf("\tdownload Download to current directory\n"); printf("\tcompare-versions \n"); printf("\t compare versions using <= < > >= = << >>\n"); printf("\tprint-architecture List installable package architectures\n"); + printf("\tdepends [-A] [pkgname|pat]+\n"); printf("\twhatdepends [-A] [pkgname|pat]+\n"); printf("\twhatdependsrec [-A] [pkgname|pat]+\n"); + printf("\twhatrecommends[-A] [pkgname|pat]+\n"); + printf("\twhatsuggests[-A] [pkgname|pat]+\n"); printf("\twhatprovides [-A] [pkgname|pat]+\n"); printf("\twhatconflicts [-A] [pkgname|pat]+\n"); printf("\twhatreplaces [-A] [pkgname|pat]+\n"); @@ -269,9 +292,11 @@ usage() printf("\t--force-downgrade Allow opkg to downgrade packages\n"); printf("\t--force-space Disable free space checks\n"); printf("\t--force-postinstall Run postinstall scripts even in offline mode\n"); + printf("\t--force-remove Remove package even if prerm script fails\n"); printf("\t--noaction No action -- test only\n"); printf("\t--download-only No action -- download only\n"); printf("\t--nodeps Do not follow dependencies\n"); + printf("\t--nocase Perform case insensitive pattern matching\n"); printf("\t--force-removal-of-dependent-packages\n"); printf("\t Remove package and all dependencies\n"); printf("\t--autoremove Remove packages that were installed\n"); @@ -328,6 +353,8 @@ main(int argc, char *argv[]) !strcmp(cmd_name,"compare-versions") || !strcmp(cmd_name,"list_installed") || !strcmp(cmd_name,"list-installed") || + !strcmp(cmd_name,"list_changed_conffiles") || + !strcmp(cmd_name,"list-changed-conffiles") || !strcmp(cmd_name,"status") ) noreadfeedsfile = 1;