forked from lix-project/lix
* Minor refactoring: use iterators to process arguments.
This commit is contained in:
parent
c68dca5dac
commit
ab723e341a
1 changed files with 79 additions and 80 deletions
159
src/nix.cc
159
src/nix.cc
|
@ -70,6 +70,9 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
typedef vector<string> Strings;
|
||||||
|
|
||||||
|
|
||||||
/* Wrapper classes that ensures that the database is closed upon
|
/* Wrapper classes that ensures that the database is closed upon
|
||||||
object destruction. */
|
object destruction. */
|
||||||
class Db2 : public Db
|
class Db2 : public Db
|
||||||
|
@ -427,7 +430,9 @@ string getPkg(string hash)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void runPkg(string hash, const vector<string> & args)
|
void runPkg(string hash,
|
||||||
|
Strings::iterator firstArg,
|
||||||
|
Strings::iterator lastArg)
|
||||||
{
|
{
|
||||||
string src;
|
string src;
|
||||||
string path;
|
string path;
|
||||||
|
@ -453,8 +458,7 @@ void runPkg(string hash, const vector<string> & args)
|
||||||
const char * args2[env.size() + 2];
|
const char * args2[env.size() + 2];
|
||||||
int i = 0;
|
int i = 0;
|
||||||
args2[i++] = runner.c_str();
|
args2[i++] = runner.c_str();
|
||||||
for (vector<string>::const_iterator it = args.begin();
|
for (Strings::const_iterator it = firstArg; it != lastArg; it++, i++)
|
||||||
it != args.end(); it++, i++)
|
|
||||||
args2[i] = it->c_str();
|
args2[i] = it->c_str();
|
||||||
args2[i] = 0;
|
args2[i] = 0;
|
||||||
|
|
||||||
|
@ -493,11 +497,11 @@ void delPkg(string hash)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void exportPkgs(string outDir, vector<string> hashes)
|
void exportPkgs(string outDir,
|
||||||
{
|
Strings::iterator firstHash,
|
||||||
for (vector<string>::iterator it = hashes.begin();
|
Strings::iterator lastHash)
|
||||||
it != hashes.end(); it++)
|
|
||||||
{
|
{
|
||||||
|
for (Strings::iterator it = firstHash; it != lastHash; it++) {
|
||||||
string hash = *it;
|
string hash = *it;
|
||||||
string pkgDir = getPkg(hash);
|
string pkgDir = getPkg(hash);
|
||||||
string tmpFile = outDir + "/export_tmp";
|
string tmpFile = outDir + "/export_tmp";
|
||||||
|
@ -616,10 +620,9 @@ void listInstalledPkgs()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void printInfo(vector<string> hashes)
|
void printInfo(Strings::iterator first, Strings::iterator last)
|
||||||
{
|
{
|
||||||
for (vector<string>::iterator it = hashes.begin();
|
for (Strings::iterator it = first; it != last; it++)
|
||||||
it != hashes.end(); it++)
|
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
cout << *it << " " << queryPkgId(*it) << endl;
|
cout << *it << " " << queryPkgId(*it) << endl;
|
||||||
|
@ -630,10 +633,10 @@ void printInfo(vector<string> hashes)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void computeClosure(const vector<string> & rootHashes,
|
void computeClosure(Strings::iterator first, Strings::iterator last,
|
||||||
set<string> & result)
|
set<string> & result)
|
||||||
{
|
{
|
||||||
list<string> workList(rootHashes.begin(), rootHashes.end());
|
list<string> workList(first, last);
|
||||||
set<string> doneSet;
|
set<string> doneSet;
|
||||||
|
|
||||||
while (!workList.empty()) {
|
while (!workList.empty()) {
|
||||||
|
@ -656,10 +659,10 @@ void computeClosure(const vector<string> & rootHashes,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void printClosure(const vector<string> & rootHashes)
|
void printClosure(Strings::iterator first, Strings::iterator last)
|
||||||
{
|
{
|
||||||
set<string> allHashes;
|
set<string> allHashes;
|
||||||
computeClosure(rootHashes, allHashes);
|
computeClosure(first, last, allHashes);
|
||||||
for (set<string>::iterator it = allHashes.begin();
|
for (set<string>::iterator it = allHashes.begin();
|
||||||
it != allHashes.end(); it++)
|
it != allHashes.end(); it++)
|
||||||
cout << *it << endl;
|
cout << *it << endl;
|
||||||
|
@ -672,10 +675,10 @@ string dotQuote(const string & s)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void printGraph(vector<string> rootHashes)
|
void printGraph(Strings::iterator first, Strings::iterator last)
|
||||||
{
|
{
|
||||||
set<string> allHashes;
|
set<string> allHashes;
|
||||||
computeClosure(rootHashes, allHashes);
|
computeClosure(first, last, allHashes);
|
||||||
|
|
||||||
cout << "digraph G {\n";
|
cout << "digraph G {\n";
|
||||||
|
|
||||||
|
@ -699,58 +702,8 @@ void printGraph(vector<string> rootHashes)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void run(vector<string> args)
|
void run(Strings args)
|
||||||
{
|
{
|
||||||
UsageError argcError("wrong number of arguments");
|
|
||||||
string cmd;
|
|
||||||
|
|
||||||
if (args.size() < 1) throw UsageError("no command specified");
|
|
||||||
|
|
||||||
cmd = args[0];
|
|
||||||
args.erase(args.begin()); // O(n)
|
|
||||||
|
|
||||||
if (cmd == "init") {
|
|
||||||
if (args.size() != 0) throw argcError;
|
|
||||||
initDB();
|
|
||||||
} else if (cmd == "verify") {
|
|
||||||
if (args.size() != 0) throw argcError;
|
|
||||||
verifyDB();
|
|
||||||
} else if (cmd == "getpkg") {
|
|
||||||
if (args.size() != 1) throw argcError;
|
|
||||||
string path = getPkg(args[0]);
|
|
||||||
cout << path << endl;
|
|
||||||
} else if (cmd == "delpkg") {
|
|
||||||
if (args.size() != 1) throw argcError;
|
|
||||||
delPkg(args[0]);
|
|
||||||
} else if (cmd == "run") {
|
|
||||||
if (args.size() < 1) throw argcError;
|
|
||||||
runPkg(args[0], vector<string>(args.begin() + 1, args.end()));
|
|
||||||
} else if (cmd == "ensure") {
|
|
||||||
if (args.size() != 1) throw argcError;
|
|
||||||
ensurePkg(args[0]);
|
|
||||||
} else if (cmd == "export") {
|
|
||||||
if (args.size() < 1) throw argcError;
|
|
||||||
exportPkgs(args[0], vector<string>(args.begin() + 1, args.end()));
|
|
||||||
} else if (cmd == "regprebuilt") {
|
|
||||||
if (args.size() != 2) throw argcError;
|
|
||||||
regPrebuilt(args[0], args[1]);
|
|
||||||
} else if (cmd == "regfile") {
|
|
||||||
if (args.size() != 1) throw argcError;
|
|
||||||
registerFile(args[0]);
|
|
||||||
} else if (cmd == "reginst") {
|
|
||||||
if (args.size() != 2) throw argcError;
|
|
||||||
registerInstalledPkg(args[0], args[1]);
|
|
||||||
} else if (cmd == "listinst") {
|
|
||||||
if (args.size() != 0) throw argcError;
|
|
||||||
listInstalledPkgs();
|
|
||||||
} else if (cmd == "info") {
|
|
||||||
printInfo(args);
|
|
||||||
} else if (cmd == "closure") {
|
|
||||||
printClosure(args);
|
|
||||||
} else if (cmd == "graph") {
|
|
||||||
printGraph(args);
|
|
||||||
} else
|
|
||||||
throw UsageError("unknown command: " + string(cmd));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -810,7 +763,7 @@ Subcommands:
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void main2(int argc, char * * argv)
|
void run(Strings::iterator argCur, Strings::iterator argEnd)
|
||||||
{
|
{
|
||||||
umask(0022);
|
umask(0022);
|
||||||
|
|
||||||
|
@ -821,8 +774,8 @@ void main2(int argc, char * * argv)
|
||||||
pkgHome = getenv(PKGHOME_ENVVAR);
|
pkgHome = getenv(PKGHOME_ENVVAR);
|
||||||
|
|
||||||
/* Parse the global flags. */
|
/* Parse the global flags. */
|
||||||
while (argc) {
|
for ( ; argCur != argEnd; argCur++) {
|
||||||
string arg(*argv);
|
string arg(*argCur);
|
||||||
if (arg == "-h" || arg == "--help") {
|
if (arg == "-h" || arg == "--help") {
|
||||||
printUsage();
|
printUsage();
|
||||||
return;
|
return;
|
||||||
|
@ -831,13 +784,57 @@ void main2(int argc, char * * argv)
|
||||||
} else if (arg[0] == '-') {
|
} else if (arg[0] == '-') {
|
||||||
throw UsageError("invalid option `" + arg + "'");
|
throw UsageError("invalid option `" + arg + "'");
|
||||||
} else break;
|
} else break;
|
||||||
argv++, argc--;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Put the remainder in a vector and pass it to run2(). */
|
UsageError argcError("wrong number of arguments");
|
||||||
vector<string> args;
|
|
||||||
while (argc--) args.push_back(*argv++);
|
/* Parse the command. */
|
||||||
run(args);
|
if (argCur == argEnd) throw UsageError("no command specified");
|
||||||
|
string cmd = *argCur++;
|
||||||
|
int argc = argEnd - argCur;
|
||||||
|
|
||||||
|
if (cmd == "init") {
|
||||||
|
if (argc != 0) throw argcError;
|
||||||
|
initDB();
|
||||||
|
} else if (cmd == "verify") {
|
||||||
|
if (argc != 0) throw argcError;
|
||||||
|
verifyDB();
|
||||||
|
} else if (cmd == "getpkg") {
|
||||||
|
if (argc != 1) throw argcError;
|
||||||
|
string path = getPkg(*argCur);
|
||||||
|
cout << path << endl;
|
||||||
|
} else if (cmd == "delpkg") {
|
||||||
|
if (argc != 1) throw argcError;
|
||||||
|
delPkg(*argCur);
|
||||||
|
} else if (cmd == "run") {
|
||||||
|
if (argc < 1) throw argcError;
|
||||||
|
runPkg(*argCur, argCur + 1, argEnd);
|
||||||
|
} else if (cmd == "ensure") {
|
||||||
|
if (argc != 1) throw argcError;
|
||||||
|
ensurePkg(*argCur);
|
||||||
|
} else if (cmd == "export") {
|
||||||
|
if (argc < 1) throw argcError;
|
||||||
|
exportPkgs(*argCur, argCur + 1, argEnd);
|
||||||
|
} else if (cmd == "regprebuilt") {
|
||||||
|
if (argc != 2) throw argcError;
|
||||||
|
regPrebuilt(*argCur, argCur[1]);
|
||||||
|
} else if (cmd == "regfile") {
|
||||||
|
if (argc != 1) throw argcError;
|
||||||
|
registerFile(*argCur);
|
||||||
|
} else if (cmd == "reginst") {
|
||||||
|
if (argc != 2) throw argcError;
|
||||||
|
registerInstalledPkg(*argCur, argCur[1]);
|
||||||
|
} else if (cmd == "listinst") {
|
||||||
|
if (argc != 0) throw argcError;
|
||||||
|
listInstalledPkgs();
|
||||||
|
} else if (cmd == "info") {
|
||||||
|
printInfo(argCur, argEnd);
|
||||||
|
} else if (cmd == "closure") {
|
||||||
|
printClosure(argCur, argEnd);
|
||||||
|
} else if (cmd == "graph") {
|
||||||
|
printGraph(argCur, argEnd);
|
||||||
|
} else
|
||||||
|
throw UsageError("unknown command: " + string(cmd));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -846,17 +843,19 @@ int main(int argc, char * * argv)
|
||||||
ATerm bottomOfStack;
|
ATerm bottomOfStack;
|
||||||
ATinit(argc, argv, &bottomOfStack);
|
ATinit(argc, argv, &bottomOfStack);
|
||||||
|
|
||||||
prog = *argv++, argc--;
|
/* Put the arguments in a vector. */
|
||||||
|
Strings args;
|
||||||
|
while (argc--) args.push_back(*argv++);
|
||||||
|
Strings::iterator argCur = args.begin(), argEnd = args.end();
|
||||||
|
|
||||||
|
prog = *argCur++;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
try {
|
try {
|
||||||
|
run(argCur, argEnd);
|
||||||
main2(argc, argv);
|
|
||||||
|
|
||||||
} catch (DbException e) {
|
} catch (DbException e) {
|
||||||
throw Error(e.what());
|
throw Error(e.what());
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (UsageError & e) {
|
} catch (UsageError & e) {
|
||||||
cerr << "error: " << e.what() << endl
|
cerr << "error: " << e.what() << endl
|
||||||
<< "Try `nix -h' for more information.\n";
|
<< "Try `nix -h' for more information.\n";
|
||||||
|
|
Loading…
Reference in a new issue