* Factored out dot graph generation into a separate file.
This commit is contained in:
		
							parent
							
								
									0d2bc68681
								
							
						
					
					
						commit
						c0bbed0959
					
				
					 4 changed files with 76 additions and 61 deletions
				
			
		|  | @ -4,7 +4,7 @@ check_PROGRAMS = test | |||
| AM_CXXFLAGS = -DSYSTEM=\"@host@\" -Wall -I.. -I../externals/inst/include $(CXXFLAGS) | ||||
| AM_LDFLAGS = -L../externals/inst/lib -ldb_cxx -lATerm $(LDFLAGS) | ||||
| 
 | ||||
| nix_SOURCES = nix.cc | ||||
| nix_SOURCES = nix.cc dotgraph.cc | ||||
| nix_LDADD = libshared.a libnix.a -ldb_cxx -lATerm | ||||
| 
 | ||||
| nix_hash_SOURCES = nix-hash.cc | ||||
|  |  | |||
							
								
								
									
										63
									
								
								src/dotgraph.cc
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								src/dotgraph.cc
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,63 @@ | |||
| #include "dotgraph.hh" | ||||
| 
 | ||||
| 
 | ||||
| static string dotQuote(const string & s) | ||||
| { | ||||
|     return "\"" + s + "\""; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| void printDotGraph(const FSIds & roots) | ||||
| { | ||||
|     FSIds workList(roots.begin(), roots.end()); | ||||
|     FSIdSet doneSet; | ||||
|              | ||||
|     cout << "digraph G {\n"; | ||||
| 
 | ||||
|     while (!workList.empty()) { | ||||
| 	FSId id = workList.front(); | ||||
| 	workList.pop_front(); | ||||
| 
 | ||||
| 	if (doneSet.find(id) == doneSet.end()) { | ||||
| 	    doneSet.insert(id); | ||||
|                      | ||||
| 	    FState fs = parseFState(termFromId(id)); | ||||
| 
 | ||||
| 	    string label, shape; | ||||
|                      | ||||
| 	    if (fs.type == FState::fsDerive) { | ||||
| 		for (FSIdSet::iterator i = fs.derive.inputs.begin(); | ||||
| 		     i != fs.derive.inputs.end(); i++) | ||||
| 		{ | ||||
| 		    workList.push_back(*i); | ||||
| 		    cout << dotQuote(*i) << " -> " | ||||
| 			 << dotQuote(id) << ";\n"; | ||||
| 		} | ||||
| 
 | ||||
| 		label = "derive"; | ||||
| 		shape = "box"; | ||||
| 		for (StringPairs::iterator i = fs.derive.env.begin(); | ||||
| 		     i != fs.derive.env.end(); i++) | ||||
| 		    if (i->first == "name") label = i->second; | ||||
| 	    } | ||||
| 
 | ||||
| 	    else if (fs.type == FState::fsSlice) { | ||||
| 		label = baseNameOf((*fs.slice.elems.begin()).first); | ||||
| 		shape = "ellipse"; | ||||
| 		if (isHash(string(label, 0, Hash::hashSize * 2)) &&  | ||||
| 		    label[Hash::hashSize * 2] == '-') | ||||
| 		    label = string(label, Hash::hashSize * 2 + 1); | ||||
| 	    } | ||||
| 
 | ||||
| 	    else abort(); | ||||
| 
 | ||||
| 	    cout << dotQuote(id) << "[label = " | ||||
| 		 << dotQuote(label) | ||||
| 		 << ", shape = " << shape | ||||
| 		 << "];\n"; | ||||
| 	} | ||||
|     } | ||||
| 
 | ||||
|     cout << "}\n"; | ||||
| 
 | ||||
| } | ||||
							
								
								
									
										8
									
								
								src/dotgraph.hh
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								src/dotgraph.hh
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,8 @@ | |||
| #ifndef __DOTGRAPH_H | ||||
| #define __DOTGRAPH_H | ||||
| 
 | ||||
| #include "fstate.hh" | ||||
| 
 | ||||
| void printDotGraph(const FSIds & roots); | ||||
| 
 | ||||
| #endif /* !__DOTGRAPH_H */ | ||||
							
								
								
									
										64
									
								
								src/nix.cc
									
										
									
									
									
								
							
							
						
						
									
										64
									
								
								src/nix.cc
									
										
									
									
									
								
							|  | @ -5,6 +5,7 @@ | |||
| #include "normalise.hh" | ||||
| #include "archive.hh" | ||||
| #include "shared.hh" | ||||
| #include "dotgraph.hh" | ||||
| 
 | ||||
| 
 | ||||
| typedef void (* Operation) (Strings opFlags, Strings opArgs); | ||||
|  | @ -80,12 +81,6 @@ static void opAdd(Strings opFlags, Strings opArgs) | |||
| } | ||||
| 
 | ||||
| 
 | ||||
| static string dotQuote(const string & s) | ||||
| { | ||||
|     return "\"" + s + "\""; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| FSId maybeNormalise(const FSId & id, bool normalise) | ||||
| { | ||||
|     return normalise ? normaliseFState(id) : id; | ||||
|  | @ -170,62 +165,11 @@ static void opQuery(Strings opFlags, Strings opArgs) | |||
|         } | ||||
| 
 | ||||
|         case qGraph: { | ||||
| 
 | ||||
|             FSIds workList; | ||||
| 
 | ||||
|             FSIds roots; | ||||
|             for (Strings::iterator i = opArgs.begin(); | ||||
|                  i != opArgs.end(); i++) | ||||
|                 workList.push_back(argToId(*i)); | ||||
| 
 | ||||
|             FSIdSet doneSet; | ||||
|              | ||||
|             cout << "digraph G {\n"; | ||||
| 
 | ||||
|             while (!workList.empty()) { | ||||
|                 FSId id = workList.front(); | ||||
|                 workList.pop_front(); | ||||
| 
 | ||||
|                 if (doneSet.find(id) == doneSet.end()) { | ||||
|                     doneSet.insert(id); | ||||
|                      | ||||
|                     FState fs = parseFState(termFromId(id)); | ||||
| 
 | ||||
|                     string label, shape; | ||||
|                      | ||||
|                     if (fs.type == FState::fsDerive) { | ||||
|                         for (FSIdSet::iterator i = fs.derive.inputs.begin(); | ||||
|                              i != fs.derive.inputs.end(); i++) | ||||
|                         { | ||||
|                             workList.push_back(*i); | ||||
|                             cout << dotQuote(*i) << " -> " | ||||
|                                  << dotQuote(id) << ";\n"; | ||||
|                         } | ||||
| 
 | ||||
|                         label = "derive"; | ||||
|                         shape = "box"; | ||||
|                         for (StringPairs::iterator i = fs.derive.env.begin(); | ||||
|                              i != fs.derive.env.end(); i++) | ||||
|                             if (i->first == "name") label = i->second; | ||||
|                     } | ||||
| 
 | ||||
|                     else if (fs.type == FState::fsSlice) { | ||||
|                         label = baseNameOf((*fs.slice.elems.begin()).first); | ||||
|                         shape = "ellipse"; | ||||
|                         if (isHash(string(label, 0, Hash::hashSize * 2)) &&  | ||||
|                             label[Hash::hashSize * 2] == '-') | ||||
|                             label = string(label, Hash::hashSize * 2 + 1); | ||||
|                     } | ||||
| 
 | ||||
|                     else abort(); | ||||
| 
 | ||||
|                     cout << dotQuote(id) << "[label = " | ||||
|                          << dotQuote(label) | ||||
|                          << ", shape = " << shape | ||||
|                          << "];\n"; | ||||
|                 } | ||||
|             } | ||||
| 
 | ||||
|             cout << "}\n"; | ||||
|                 roots.push_back(argToId(*i)); | ||||
| 	    printDotGraph(roots); | ||||
|             break; | ||||
|         } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue