top-level: Deprecate top-level {build,host,target}Platform
				
					
				
			I don't know when we can/should remove them, but this at least gets people to stop using them. The preferred alternatives also date back to 17.09 so writing forward-compatable code without extra conditions is easy. Beginning with these as they are the least controversial.
This commit is contained in:
		
							parent
							
								
									51907d257c
								
							
						
					
					
						commit
						e51f736076
					
				| @ -47,13 +47,9 @@ | |||||||
| 
 | 
 | ||||||
|    <para> |    <para> | ||||||
|     In Nixpkgs, these three platforms are defined as attribute sets under the |     In Nixpkgs, these three platforms are defined as attribute sets under the | ||||||
|     names <literal>buildPlatform</literal>, <literal>hostPlatform</literal>, |     names <literal>buildPlatform</literal>, <literal>hostPlatform</literal>, and | ||||||
|     and <literal>targetPlatform</literal>. All three are always defined as |     <literal>targetPlatform</literal>. They are always defined as attributes in | ||||||
|     attributes in the standard environment, and at the top level. That means |     the standard environment. That means one can access them like: | ||||||
|     one can get at them just like a dependency in a function that is imported |  | ||||||
|     with <literal>callPackage</literal>: |  | ||||||
| <programlisting>{ stdenv, buildPlatform, hostPlatform, fooDep, barDep, .. }: ...buildPlatform...</programlisting> |  | ||||||
|     , or just off <varname>stdenv</varname>: |  | ||||||
| <programlisting>{ stdenv, fooDep, barDep, .. }: ...stdenv.buildPlatform...</programlisting> | <programlisting>{ stdenv, fooDep, barDep, .. }: ...stdenv.buildPlatform...</programlisting> | ||||||
|     . |     . | ||||||
|    </para> |    </para> | ||||||
|  | |||||||
| @ -79,11 +79,17 @@ let | |||||||
| 
 | 
 | ||||||
|   # The old identifiers for cross-compiling. These should eventually be removed, |   # The old identifiers for cross-compiling. These should eventually be removed, | ||||||
|   # and the packages that rely on them refactored accordingly. |   # and the packages that rely on them refactored accordingly. | ||||||
|   platformCompat = self: super: let |   platformCompat = self: super: { | ||||||
|     inherit (super.stdenv) buildPlatform hostPlatform targetPlatform; |     buildPlatform = lib.warn | ||||||
|   in { |       "top-level `buildPlatform` is deprecated since 18.09. Please use `stdenv.buildPlatform`." | ||||||
|     inherit buildPlatform hostPlatform targetPlatform; |       super.stdenv.buildPlatform; | ||||||
|     inherit (buildPlatform) system; |     hostPlatform = lib.warn | ||||||
|  |       "top-level `hostPlatform` is deprecated since 18.09. Please use `stdenv.hostPlatform`." | ||||||
|  |       super.stdenv.hostPlatform; | ||||||
|  |     targetPlatform = lib.warn | ||||||
|  |       "top-level `targetPlatform` is deprecated since 18.09. Please use `stdenv.targetPlatform`." | ||||||
|  |       super.stdenv.targetPlatform; | ||||||
|  |     inherit (super.stdenv.buildPlatform) system; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   splice = self: super: import ./splice.nix lib self (buildPackages != null); |   splice = self: super: import ./splice.nix lib self (buildPackages != null); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 John Ericson
						John Ericson