X-Git-Url: https://git.saurik.com/apt.git/blobdiff_plain/cbbee23e7768750ca1c8b49bdfbf8a650131bbb6..d27daedb6a0bf672508072100f20233d08ccf0e0:/apt-pkg/contrib/cmndline.cc diff --git a/apt-pkg/contrib/cmndline.cc b/apt-pkg/contrib/cmndline.cc index 60ce90f1f..c8a6e2787 100644 --- a/apt-pkg/contrib/cmndline.cc +++ b/apt-pkg/contrib/cmndline.cc @@ -83,43 +83,6 @@ char const * CommandLine::GetCommand(Dispatch const * const Map, return Map[j].Match; } return NULL; -} -char const * CommandLine::GetCommand(DispatchWithHelp const * const Map, - unsigned int const argc, char const * const * const argv) -{ - // if there is a -- on the line there must be the word we search for either - // before it (as -- marks the end of the options) or right after it (as we can't - // decide if the command is actually an option, given that in theory, you could - // have parameters named like commands) - for (size_t i = 1; i < argc; ++i) - { - if (strcmp(argv[i], "--") != 0) - continue; - // check if command is before -- - for (size_t k = 1; k < i; ++k) - for (size_t j = 0; Map[j].Match != NULL; ++j) - if (strcmp(argv[k], Map[j].Match) == 0) - return Map[j].Match; - // see if the next token after -- is the command - ++i; - if (i < argc) - for (size_t j = 0; Map[j].Match != NULL; ++j) - if (strcmp(argv[i], Map[j].Match) == 0) - return Map[j].Match; - // we found a --, but not a command - return NULL; - } - // no --, so search for the first word matching a command - // FIXME: How like is it that an option parameter will be also a valid Match ? - for (size_t i = 1; i < argc; ++i) - { - if (*(argv[i]) == '-') - continue; - for (size_t j = 0; Map[j].Match != NULL; ++j) - if (strcmp(argv[i], Map[j].Match) == 0) - return Map[j].Match; - } - return NULL; } /*}}}*/ // CommandLine::Parse - Main action member /*{{{*/ @@ -242,17 +205,11 @@ bool CommandLine::HandleOpt(int &I,int argc,const char *argv[], /* Determine the possible location of an option or 0 if their is no option */ - if (Opt[1] == 0 || (Opt[1] == '=' && Opt[2] == 0)) + if (Opt[1] == 0) { if (I + 1 < argc && argv[I+1][0] != '-') Argument = argv[I+1]; - - // Equals was specified but we fell off the end! - if (Opt[1] == '=' && Argument == 0) - return _error->Error(_("Option %s requires an argument."),argv[I]); - if (Opt[1] == '=') - CertainArg = true; - + IncI = 1; } else @@ -281,20 +238,11 @@ bool CommandLine::HandleOpt(int &I,int argc,const char *argv[], // Arbitrary item specification if ((A->Flags & ArbItem) == ArbItem) { - const char *J = strchr(Argument, '='); - if (J == NULL) + const char * const J = strchr(Argument, '='); + if (J == nullptr) return _error->Error(_("Option %s: Configuration item specification must have an =."),argv[I]); - // = is trailing - if (J[1] == 0) - { - if (I+1 >= argc) - return _error->Error(_("Option %s: Configuration item specification must have an =."),argv[I]); - Conf->Set(string(Argument,J-Argument),string(argv[I++ +1])); - } - else - Conf->Set(string(Argument,J-Argument),string(J+1)); - + Conf->Set(string(Argument,J-Argument), J+1); return true; } @@ -411,7 +359,7 @@ unsigned int CommandLine::FileSize() const } /*}}}*/ // CommandLine::DispatchArg - Do something with the first arg /*{{{*/ -bool CommandLine::DispatchArg(DispatchWithHelp *Map,bool NoMatch) +bool CommandLine::DispatchArg(Dispatch const * const Map,bool NoMatch) { int I; for (I = 0; Map[I].Match != 0; I++) @@ -436,26 +384,8 @@ bool CommandLine::DispatchArg(DispatchWithHelp *Map,bool NoMatch) } bool CommandLine::DispatchArg(Dispatch *Map,bool NoMatch) { - int I; - for (I = 0; Map[I].Match != 0; I++) - { - if (strcmp(FileList[0],Map[I].Match) == 0) - { - bool Res = Map[I].Handler(*this); - if (Res == false && _error->PendingError() == false) - _error->Error("Handler silently failed"); - return Res; - } - } - - // No matching name - if (Map[I].Match == 0) - { - if (NoMatch == true) - _error->Error(_("Invalid operation %s"),FileList[0]); - } - - return false; + Dispatch const * const Map2 = Map; + return DispatchArg(Map2, NoMatch); } /*}}}*/ // CommandLine::SaveInConfig - for output later in a logfile or so /*{{{*/