Add basic "nix run" command
This commit is contained in:
		
							parent
							
								
									4494000e04
								
							
						
					
					
						commit
						6f2d51287c
					
				
					 1 changed files with 62 additions and 0 deletions
				
			
		
							
								
								
									
										62
									
								
								src/nix/run.cc
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								src/nix/run.cc
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,62 @@
 | 
				
			||||||
 | 
					#include "command.hh"
 | 
				
			||||||
 | 
					#include "common-args.hh"
 | 
				
			||||||
 | 
					#include "installables.hh"
 | 
				
			||||||
 | 
					#include "shared.hh"
 | 
				
			||||||
 | 
					#include "store-api.hh"
 | 
				
			||||||
 | 
					#include "derivations.hh"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					using namespace nix;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct CmdRun : StoreCommand, MixInstallables
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    CmdRun()
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    std::string name() override
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        return "run";
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    std::string description() override
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        return "run a shell in which the specified packages are available";
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void run(ref<Store> store) override
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        auto elems = evalInstallables(store);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        PathSet pathsToBuild;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for (auto & elem : elems) {
 | 
				
			||||||
 | 
					            if (elem.isDrv)
 | 
				
			||||||
 | 
					                pathsToBuild.insert(elem.drvPath);
 | 
				
			||||||
 | 
					            else
 | 
				
			||||||
 | 
					                pathsToBuild.insert(elem.outPaths.begin(), elem.outPaths.end());
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        printMissing(store, pathsToBuild);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        store->buildPaths(pathsToBuild);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        PathSet outPaths;
 | 
				
			||||||
 | 
					        for (auto & path : pathsToBuild)
 | 
				
			||||||
 | 
					            if (isDerivation(path)) {
 | 
				
			||||||
 | 
					                Derivation drv = store->derivationFromPath(path);
 | 
				
			||||||
 | 
					                for (auto & output : drv.outputs)
 | 
				
			||||||
 | 
					                    outPaths.insert(output.second.path);
 | 
				
			||||||
 | 
					            } else
 | 
				
			||||||
 | 
					                outPaths.insert(path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        auto unixPath = tokenizeString<Strings>(getEnv("PATH"), ":");
 | 
				
			||||||
 | 
					        for (auto & path : outPaths)
 | 
				
			||||||
 | 
					            if (pathExists(path + "/bin"))
 | 
				
			||||||
 | 
					                unixPath.push_front(path + "/bin");
 | 
				
			||||||
 | 
					        setenv("PATH", concatStringsSep(":", unixPath).c_str(), 1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        execlp("bash", "bash", nullptr);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static RegisterCommand r1(make_ref<CmdRun>());
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue