56 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| # This is a test to show that mkAliasOptionModule sets the priority correctly
 | |
| # for aliased options.
 | |
| #
 | |
| # This test shows that an alias with a high priority is able to override
 | |
| # a non-aliased option.
 | |
| 
 | |
| { config, lib, ... }:
 | |
| 
 | |
| with lib;
 | |
| 
 | |
| {
 | |
|   options = {
 | |
|     # A simple boolean option that can be enabled or disabled.
 | |
|     enable = lib.mkOption {
 | |
|       type = types.nullOr types.bool;
 | |
|       default = null;
 | |
|       example = true;
 | |
|       description = ''
 | |
|         Some descriptive text
 | |
|       '';
 | |
|     };
 | |
| 
 | |
|     # mkAliasOptionModule sets warnings, so this has to be defined.
 | |
|     warnings = mkOption {
 | |
|       internal = true;
 | |
|       default = [];
 | |
|       type = types.listOf types.str;
 | |
|       example = [ "The `foo' service is deprecated and will go away soon!" ];
 | |
|       description = ''
 | |
|         This option allows modules to show warnings to users during
 | |
|         the evaluation of the system configuration.
 | |
|       '';
 | |
|     };
 | |
|   };
 | |
| 
 | |
|   imports = [
 | |
|     # Create an alias for the "enable" option.
 | |
|     (mkAliasOptionModule [ "enableAlias" ] [ "enable" ])
 | |
| 
 | |
|     # Disable the aliased option with a high priority so it
 | |
|     # should override the next import.
 | |
|     ( { config, lib, ... }:
 | |
|       {
 | |
|         enableAlias = lib.mkForce false;
 | |
|       }
 | |
|     )
 | |
| 
 | |
|     # Enable the normal (non-aliased) option.
 | |
|     ( { config, lib, ... }:
 | |
|       {
 | |
|         enable = true;
 | |
|       }
 | |
|     )
 | |
|   ];
 | |
| }
 | 
