* A better substitute mechanism. Instead of generating a store expression for each store path for which we have a substitute, we can have a single store expression that builds a generic program that is invoked to build the desired store path, which is passed as an argument. This means that operations like `nix-pull' only produce O(1) files instead of O(N) files in the store when registering N substitutes. (It consumes O(N) database storage, of course, but that's not a performance problem). * Added a test for the substitute mechanism. * `nix-store --substitute' reads the substitutes from standard input, instead of from the command line. This prevents us from running into the kernel's limit on command line length.
		
			
				
	
	
		
			22 lines
		
	
	
	
		
			330 B
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			22 lines
		
	
	
	
		
			330 B
		
	
	
	
		
			Bash
		
	
	
	
	
	
# Set a PATH (!!! impure).
 | 
						|
export PATH=/bin:/usr/bin:$PATH
 | 
						|
 | 
						|
mkdir $out
 | 
						|
 | 
						|
cat > $out/substituter <<EOF
 | 
						|
#! /bin/sh -ex
 | 
						|
echo \$*
 | 
						|
 | 
						|
case \$* in
 | 
						|
    *aaaa*)
 | 
						|
        echo "Closure([\"\$2\"],[(\"\$2\",[])])" > \$1
 | 
						|
        ;;
 | 
						|
    *)
 | 
						|
        mkdir \$1
 | 
						|
        echo \$3 \$4 > \$1/hello
 | 
						|
        ;;
 | 
						|
esac        
 | 
						|
EOF
 | 
						|
 | 
						|
chmod +x $out/substituter
 | 
						|
 |