forked from lix-project/lix
* Refactoring: move initialisation and argument parsing into a shared
file.
This commit is contained in:
parent
01b34fe584
commit
f826e432aa
|
@ -3,7 +3,7 @@ check_PROGRAMS = test
|
||||||
|
|
||||||
AM_CXXFLAGS = -DSYSTEM=\"@host@\" -Wall -I..
|
AM_CXXFLAGS = -DSYSTEM=\"@host@\" -Wall -I..
|
||||||
|
|
||||||
nix_SOURCES = nix.cc
|
nix_SOURCES = nix.cc shared.cc
|
||||||
nix_LDADD = libnix.a -ldb_cxx-4 -lATerm
|
nix_LDADD = libnix.a -ldb_cxx-4 -lATerm
|
||||||
|
|
||||||
TESTS = test
|
TESTS = test
|
||||||
|
|
|
@ -106,7 +106,7 @@ static void runProgram(const string & program, Environment env)
|
||||||
|
|
||||||
} catch (exception & e) {
|
} catch (exception & e) {
|
||||||
cerr << format("build error: %1%\n") % e.what();
|
cerr << format("build error: %1%\n") % e.what();
|
||||||
<EFBFBD> }
|
}
|
||||||
_exit(1);
|
_exit(1);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
56
src/nix.cc
56
src/nix.cc
|
@ -1,11 +1,10 @@
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
#include "config.h"
|
|
||||||
|
|
||||||
#include "globals.hh"
|
#include "globals.hh"
|
||||||
#include "values.hh"
|
#include "values.hh"
|
||||||
#include "eval.hh"
|
#include "eval.hh"
|
||||||
#include "archive.hh"
|
#include "archive.hh"
|
||||||
|
#include "shared.hh"
|
||||||
|
|
||||||
|
|
||||||
typedef void (* Operation) (Strings opFlags, Strings opArgs);
|
typedef void (* Operation) (Strings opFlags, Strings opArgs);
|
||||||
|
@ -224,39 +223,14 @@ static void opInit(Strings opFlags, Strings opArgs)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Initialize, process arguments, and dispatch to the right
|
/* Scan the arguments; find the operation, set global flags, put all
|
||||||
operation. */
|
other flags in a list, and put all other arguments in another
|
||||||
static void run(int argc, char * * argv)
|
list. */
|
||||||
|
void run(Strings args)
|
||||||
{
|
{
|
||||||
/* Setup Nix paths. */
|
|
||||||
nixStore = NIX_STORE_DIR;
|
|
||||||
nixLogDir = NIX_LOG_DIR;
|
|
||||||
nixDB = (string) NIX_STATE_DIR + "/nixstate.db";
|
|
||||||
|
|
||||||
/* Put the arguments in a vector. */
|
|
||||||
Strings args;
|
|
||||||
while (argc--) args.push_back(*argv++);
|
|
||||||
args.erase(args.begin());
|
|
||||||
|
|
||||||
/* Expand compound dash options (i.e., `-qlf' -> `-q -l -f'). */
|
|
||||||
for (Strings::iterator it = args.begin();
|
|
||||||
it != args.end(); )
|
|
||||||
{
|
|
||||||
string arg = *it;
|
|
||||||
if (arg.length() > 2 && arg[0] == '-' && arg[1] != '-') {
|
|
||||||
for (unsigned int i = 1; i < arg.length(); i++)
|
|
||||||
args.insert(it, (string) "-" + arg[i]);
|
|
||||||
it = args.erase(it);
|
|
||||||
} else it++;
|
|
||||||
}
|
|
||||||
|
|
||||||
Strings opFlags, opArgs;
|
Strings opFlags, opArgs;
|
||||||
Operation op = 0;
|
Operation op = 0;
|
||||||
|
|
||||||
/* Scan the arguments; find the operation, set global flags, put
|
|
||||||
all other flags in a list, and put all other arguments in
|
|
||||||
another list. */
|
|
||||||
|
|
||||||
for (Strings::iterator it = args.begin();
|
for (Strings::iterator it = args.begin();
|
||||||
it != args.end(); it++)
|
it != args.end(); it++)
|
||||||
{
|
{
|
||||||
|
@ -291,22 +265,4 @@ static void run(int argc, char * * argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char * * argv)
|
string programId = "nix";
|
||||||
{
|
|
||||||
/* ATerm setup. */
|
|
||||||
ATerm bottomOfStack;
|
|
||||||
ATinit(argc, argv, &bottomOfStack);
|
|
||||||
|
|
||||||
try {
|
|
||||||
run(argc, argv);
|
|
||||||
} catch (UsageError & e) {
|
|
||||||
cerr << "error: " << e.what() << endl
|
|
||||||
<< "Try `nix --help' for more information.\n";
|
|
||||||
return 1;
|
|
||||||
} catch (exception & e) {
|
|
||||||
cerr << "error: " << e.what() << endl;
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
63
src/shared.cc
Normal file
63
src/shared.cc
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
#include <aterm2.h>
|
||||||
|
}
|
||||||
|
|
||||||
|
#include "globals.hh"
|
||||||
|
#include "shared.hh"
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
|
||||||
|
/* Initialize and reorder arguments, then call the actual argument
|
||||||
|
processor. */
|
||||||
|
static void initAndRun(int argc, char * * argv)
|
||||||
|
{
|
||||||
|
/* Setup Nix paths. */
|
||||||
|
nixStore = NIX_STORE_DIR;
|
||||||
|
nixLogDir = NIX_LOG_DIR;
|
||||||
|
nixDB = (string) NIX_STATE_DIR + "/nixstate.db";
|
||||||
|
|
||||||
|
/* Put the arguments in a vector. */
|
||||||
|
Strings args;
|
||||||
|
while (argc--) args.push_back(*argv++);
|
||||||
|
args.erase(args.begin());
|
||||||
|
|
||||||
|
/* Expand compound dash options (i.e., `-qlf' -> `-q -l -f'). */
|
||||||
|
for (Strings::iterator it = args.begin();
|
||||||
|
it != args.end(); )
|
||||||
|
{
|
||||||
|
string arg = *it;
|
||||||
|
if (arg.length() > 2 && arg[0] == '-' && arg[1] != '-') {
|
||||||
|
for (unsigned int i = 1; i < arg.length(); i++)
|
||||||
|
args.insert(it, (string) "-" + arg[i]);
|
||||||
|
it = args.erase(it);
|
||||||
|
} else it++;
|
||||||
|
}
|
||||||
|
|
||||||
|
run(args);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main(int argc, char * * argv)
|
||||||
|
{
|
||||||
|
/* ATerm setup. */
|
||||||
|
ATerm bottomOfStack;
|
||||||
|
ATinit(argc, argv, &bottomOfStack);
|
||||||
|
|
||||||
|
try {
|
||||||
|
initAndRun(argc, argv);
|
||||||
|
} catch (UsageError & e) {
|
||||||
|
cerr << format(
|
||||||
|
"error: %1%\n"
|
||||||
|
"Try `%2% --help' for more information.\n")
|
||||||
|
% e.what() % programId;
|
||||||
|
return 1;
|
||||||
|
} catch (exception & e) {
|
||||||
|
cerr << format("error: %1%\n") % e.what();
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
15
src/shared.hh
Normal file
15
src/shared.hh
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
#ifndef __SHARED_H
|
||||||
|
#define __SHARED_H
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include "util.hh"
|
||||||
|
|
||||||
|
|
||||||
|
void run(Strings args);
|
||||||
|
|
||||||
|
|
||||||
|
extern string programId;
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* !__SHARED_H */
|
Loading…
Reference in a new issue