* Debug levels. Use `--verbose / -v LEVEL' to display only messages
up to the given verbosity levels.  These currently are:
    lvlError = 0, 
    lvlNormal = 5,
    lvlDebug = 10,
    lvlDebugMore = 15
  although only lvlError and lvlDebug are actually used right now.
			
			
This commit is contained in:
		
							parent
							
								
									b75719b984
								
							
						
					
					
						commit
						1a7468a57a
					
				
					 8 changed files with 68 additions and 25 deletions
				
			
		
							
								
								
									
										10
									
								
								src/fix.cc
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								src/fix.cc
									
										
									
									
									
								
							|  | @ -310,6 +310,16 @@ void run(Strings args) | |||
|                 throw UsageError(format("argument required in `%1%'") % arg); | ||||
|             state.searchDirs.push_back(*it++); | ||||
|         } | ||||
|         else if (arg == "--verbose" || arg == "-v") { | ||||
|             if (it == args.end()) throw UsageError( | ||||
|                 format("`%1%' requires an argument") % arg); | ||||
|             istringstream str(*it++); | ||||
|             int lvl; | ||||
|             str >> lvl; | ||||
|             if (str.fail()) throw UsageError( | ||||
|                 format("`%1%' requires an integer argument") % arg); | ||||
|             verbosity = (Verbosity) lvl; | ||||
|         } | ||||
|         else if (arg[0] == '-') | ||||
|             throw UsageError(format("unknown flag `%1%`") % arg); | ||||
|         else | ||||
|  |  | |||
							
								
								
									
										16
									
								
								src/nix.cc
									
										
									
									
									
								
							
							
						
						
									
										16
									
								
								src/nix.cc
									
										
									
									
									
								
							|  | @ -1,4 +1,5 @@ | |||
| #include <iostream> | ||||
| #include <sstream> | ||||
| 
 | ||||
| #include "globals.hh" | ||||
| #include "normalise.hh" | ||||
|  | @ -278,10 +279,9 @@ void run(Strings args) | |||
|     Strings opFlags, opArgs; | ||||
|     Operation op = 0; | ||||
| 
 | ||||
|     for (Strings::iterator it = args.begin(); | ||||
|          it != args.end(); it++) | ||||
|     for (Strings::iterator it = args.begin(); it != args.end(); ) | ||||
|     { | ||||
|         string arg = *it; | ||||
|         string arg = *it++; | ||||
| 
 | ||||
|         Operation oldOp = op; | ||||
| 
 | ||||
|  | @ -307,6 +307,16 @@ void run(Strings args) | |||
|             op = opVerify; | ||||
|         else if (arg == "--path" || arg == "-p") | ||||
|             pathArgs = true; | ||||
|         else if (arg == "--verbose" || arg == "-v") { | ||||
|             if (it == args.end()) throw UsageError( | ||||
|                 format("`%1%' requires an argument") % arg); | ||||
|             istringstream str(*it++); | ||||
|             int lvl; | ||||
|             str >> lvl; | ||||
|             if (str.fail()) throw UsageError( | ||||
|                 format("`%1%' requires an integer argument") % arg); | ||||
|             verbosity = (Verbosity) lvl; | ||||
|         } | ||||
|         else if (arg[0] == '-') | ||||
|             opFlags.push_back(arg); | ||||
|         else | ||||
|  |  | |||
|  | @ -26,8 +26,7 @@ typedef set<FSId> FSIdSet; | |||
| 
 | ||||
| Slice normaliseFState(FSId id, FSIdSet pending) | ||||
| { | ||||
|     debug(format("normalising fstate %1%") % (string) id); | ||||
|     Nest nest(true); | ||||
|     Nest nest(lvlDebug, format("normalising fstate %1%") % (string) id); | ||||
| 
 | ||||
|     /* Try to substitute $id$ by any known successors in order to
 | ||||
|        speed up the rewrite process. */ | ||||
|  | @ -177,8 +176,7 @@ Slice normaliseFState(FSId id, FSIdSet pending) | |||
| 
 | ||||
| void realiseSlice(const Slice & slice, FSIdSet pending) | ||||
| { | ||||
|     debug(format("realising slice")); | ||||
|     Nest nest(true); | ||||
|     Nest nest(lvlDebug, format("realising slice")); | ||||
| 
 | ||||
|     /* Perhaps all paths already contain the right id? */ | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,4 +1,5 @@ | |||
| #include <iostream> | ||||
| #include <cctype> | ||||
| 
 | ||||
| extern "C" { | ||||
| #include <aterm2.h> | ||||
|  | @ -32,7 +33,12 @@ static void initAndRun(int argc, char * * argv) | |||
|         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]); | ||||
|                 if (isalpha(arg[i])) | ||||
|                     args.insert(it, (string) "-" + arg[i]); | ||||
|                 else { | ||||
|                     args.insert(it, string(arg, i)); | ||||
|                     break; | ||||
|                 } | ||||
|             it = args.erase(it); | ||||
|         } else it++; | ||||
|     } | ||||
|  | @ -50,18 +56,21 @@ int main(int argc, char * * argv) | |||
|     try { | ||||
|         initAndRun(argc, argv); | ||||
|     } catch (UsageError & e) { | ||||
|         cerr << format( | ||||
|             "error: %1%\n" | ||||
|             "Try `%2% --help' for more information.\n") | ||||
|             % e.what() % programId; | ||||
|         msg(lvlError,  | ||||
|             format( | ||||
|                 "error: %1%\n" | ||||
|                 "Try `%2% --help' for more information.") | ||||
|             % e.what() % programId); | ||||
|         return 1; | ||||
|     } catch (Error & e) { | ||||
|         cerr << format("error: %1%\n") % e.msg(); | ||||
|         msg(lvlError, format("error: %1%") % e.msg()); | ||||
|         return 1; | ||||
|     } catch (exception & e) { | ||||
|         cerr << format("error: %1%\n") % e.what(); | ||||
|         msg(lvlError, format("error: %1%") % e.what()); | ||||
|         return 1; | ||||
|     } | ||||
| 
 | ||||
|     return 0; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -168,7 +168,7 @@ string expandId(const FSId & id, const string & target, | |||
|     const string & prefix, FSIdSet pending) | ||||
| { | ||||
|     debug(format("expanding %1%") % (string) id); | ||||
|     Nest nest(true); | ||||
|     Nest nest(lvlDebug, format("expanding %1%") % (string) id); | ||||
| 
 | ||||
|     Strings paths; | ||||
| 
 | ||||
|  |  | |||
|  | @ -12,8 +12,7 @@ | |||
| 
 | ||||
| void realise(FSId id) | ||||
| { | ||||
|     debug(format("TEST: realising %1%") % (string) id); | ||||
|     Nest nest(true); | ||||
|     Nest nest(lvlDebug, format("TEST: realising %1%") % (string) id); | ||||
|     Slice slice = normaliseFState(id); | ||||
|     realiseSlice(slice); | ||||
| } | ||||
|  |  | |||
							
								
								
									
										18
									
								
								src/util.cc
									
										
									
									
									
								
							
							
						
						
									
										18
									
								
								src/util.cc
									
										
									
									
									
								
							|  | @ -130,13 +130,20 @@ void deletePath(string path) | |||
| } | ||||
| 
 | ||||
| 
 | ||||
| Verbosity verbosity = lvlNormal; | ||||
| 
 | ||||
| static int nestingLevel = 0; | ||||
| 
 | ||||
| 
 | ||||
| Nest::Nest(bool nest) | ||||
| Nest::Nest(Verbosity level, const format & f) | ||||
| { | ||||
|     this->nest = nest; | ||||
|     if (nest) nestingLevel++; | ||||
|     if (level > verbosity) | ||||
|         nest = false; | ||||
|     else { | ||||
|         msg(level, f); | ||||
|         nest = true; | ||||
|         nestingLevel++; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
|  | @ -146,8 +153,9 @@ Nest::~Nest() | |||
| } | ||||
| 
 | ||||
| 
 | ||||
| void msg(const format & f) | ||||
| void msg(Verbosity level, const format & f) | ||||
| { | ||||
|     if (level > verbosity) return; | ||||
|     string spaces; | ||||
|     for (int i = 0; i < nestingLevel; i++) | ||||
|         spaces += "|   "; | ||||
|  | @ -157,7 +165,7 @@ void msg(const format & f) | |||
| 
 | ||||
| void debug(const format & f) | ||||
| { | ||||
|     msg(format("debug: %1%") % f.str()); | ||||
|     msg(lvlDebug, format("debug: %1%") % f.str()); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										15
									
								
								src/util.hh
									
										
									
									
									
								
							
							
						
						
									
										15
									
								
								src/util.hh
									
										
									
									
									
								
							|  | @ -72,17 +72,26 @@ void deletePath(string path); | |||
| 
 | ||||
| /* Messages. */ | ||||
| 
 | ||||
| typedef enum {  | ||||
|     lvlError = 0,  | ||||
|     lvlNormal = 5, | ||||
|     lvlDebug = 10, | ||||
|     lvlDebugMore = 15 | ||||
| } Verbosity; | ||||
| 
 | ||||
| extern Verbosity verbosity; /* supress msgs > this */ | ||||
| 
 | ||||
| class Nest | ||||
| { | ||||
| private: | ||||
|     bool nest; | ||||
| public: | ||||
|     Nest(bool nest); | ||||
|     Nest(Verbosity level, const format & f); | ||||
|     ~Nest(); | ||||
| }; | ||||
| 
 | ||||
| void msg(const format & f); | ||||
| void debug(const format & f); | ||||
| void msg(Verbosity level, const format & f); | ||||
| void debug(const format & f); /* shorthand */ | ||||
| 
 | ||||
| 
 | ||||
| /* Wrappers arount read()/write() that read/write exactly the
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue