nix path-info: Add
Forgot to commit this earlier...
This commit is contained in:
		
							parent
							
								
									69e3ffb076
								
							
						
					
					
						commit
						1a71495273
					
				
					 1 changed files with 75 additions and 0 deletions
				
			
		
							
								
								
									
										75
									
								
								src/nix/path-info.cc
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								src/nix/path-info.cc
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,75 @@ | ||||||
|  | #include "command.hh" | ||||||
|  | #include "progress-bar.hh" | ||||||
|  | #include "shared.hh" | ||||||
|  | #include "store-api.hh" | ||||||
|  | 
 | ||||||
|  | #include <iomanip> | ||||||
|  | 
 | ||||||
|  | using namespace nix; | ||||||
|  | 
 | ||||||
|  | struct CmdPathInfo : StorePathsCommand | ||||||
|  | { | ||||||
|  |     bool showSize = false; | ||||||
|  |     bool showClosureSize = false; | ||||||
|  | 
 | ||||||
|  |     CmdPathInfo() | ||||||
|  |     { | ||||||
|  |         mkFlag('s', "size", "print size of the NAR dump of each path", &showSize); | ||||||
|  |         mkFlag('S', "closure-size", "print sum size of the NAR dumps of the closure of each path", &showClosureSize); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     std::string name() override | ||||||
|  |     { | ||||||
|  |         return "path-info"; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     std::string description() override | ||||||
|  |     { | ||||||
|  |         return "query information about store paths"; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     Examples examples() override | ||||||
|  |     { | ||||||
|  |         return { | ||||||
|  |             Example{ | ||||||
|  |                 "To show the closure sizes of every path in the current NixOS system closure, sorted by size:", | ||||||
|  |                 "nix path-info -rS /run/current-system | sort -nk2" | ||||||
|  |             }, | ||||||
|  |             Example{ | ||||||
|  |                 "To check the existence of a path in a binary cache:", | ||||||
|  |                 "nix path-info -r /nix/store/7qvk5c91...-geeqie-1.1 --store https://cache.nixos.org/" | ||||||
|  |             }, | ||||||
|  |         }; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     void run(ref<Store> store, Paths storePaths) override | ||||||
|  |     { | ||||||
|  |         size_t pathLen = 0; | ||||||
|  |         for (auto & storePath : storePaths) | ||||||
|  |             pathLen = std::max(pathLen, storePath.size()); | ||||||
|  | 
 | ||||||
|  |         for (auto & storePath : storePaths) { | ||||||
|  |             if (!store->isValidPath(storePath)) | ||||||
|  |                 throw Error(format("path ‘%s’ is not valid") % storePath); | ||||||
|  | 
 | ||||||
|  |             std::cout << storePath << std::string(pathLen - storePath.size(), ' '); | ||||||
|  | 
 | ||||||
|  |             if (showSize) { | ||||||
|  |                 std::cout << '\t' << std::setw(11) << store->queryPathInfo(storePath)->narSize; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (showClosureSize) { | ||||||
|  |                 size_t totalSize = 0; | ||||||
|  |                 PathSet closure; | ||||||
|  |                 store->computeFSClosure(storePath, closure, false, false); | ||||||
|  |                 for (auto & p : closure) | ||||||
|  |                     totalSize += store->queryPathInfo(p)->narSize; | ||||||
|  |                 std::cout << '\t' << std::setw(11) << totalSize; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             std::cout << std::endl; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | static RegisterCommand r1(make_ref<CmdPathInfo>()); | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue