mirror of
				https://github.com/SquidDev-CC/CC-Tweaked
				synced 2025-10-22 09:27:39 +00:00 
			
		
		
		
	Preserve default values in configuration
Before we were setting the default as the previous value each time. Here we store each property in a separate field, allowing us to access them without setting a default.
This commit is contained in:
		| @@ -99,8 +99,6 @@ public class ComputerCraft | ||||
|     public static final int pocketComputerGUIID = 106; | ||||
|  | ||||
|     // Configuration options | ||||
|     public static Configuration config; | ||||
|  | ||||
|     public static boolean http_enable = true; | ||||
|     public static String http_whitelist = "*"; | ||||
|     public static boolean disable_lua51_features = false; | ||||
| @@ -164,6 +162,31 @@ public class ComputerCraft | ||||
|         public static TurtleModem advancedModem; | ||||
|     } | ||||
|  | ||||
|     public static class Config { | ||||
|         public static Configuration config; | ||||
|  | ||||
|         public static Property http_enable; | ||||
|         public static Property http_whitelist; | ||||
|         public static Property disable_lua51_features; | ||||
|         public static Property default_computer_settings; | ||||
|  | ||||
|         public static Property enableCommandBlock; | ||||
|         public static Property turtlesNeedFuel; | ||||
|         public static Property turtleFuelLimit; | ||||
|         public static Property advancedTurtleFuelLimit; | ||||
|         public static Property turtlesObeyBlockProtection; | ||||
|         public static Property turtlesCanPush; | ||||
|  | ||||
|         public static Property modem_range; | ||||
|         public static Property modem_highAltitudeRange; | ||||
|         public static Property modem_rangeDuringStorm; | ||||
|         public static Property modem_highAltitudeRangeDuringStorm; | ||||
|  | ||||
|         public static Property computerSpaceLimit; | ||||
|         public static Property floppySpaceLimit; | ||||
|  | ||||
|     } | ||||
|  | ||||
|     // Registries | ||||
|     public static ClientComputerRegistry clientComputerRegistry = new ClientComputerRegistry(); | ||||
|     public static ServerComputerRegistry serverComputerRegistry = new ServerComputerRegistry(); | ||||
| @@ -198,8 +221,61 @@ public class ComputerCraft | ||||
|     public void preInit( FMLPreInitializationEvent event ) | ||||
|     { | ||||
|         // Load config | ||||
|         config = new Configuration( event.getSuggestedConfigurationFile() ); | ||||
|         config.load(); | ||||
|         Config.config = new Configuration( event.getSuggestedConfigurationFile() ); | ||||
|         Config.config.load(); | ||||
|  | ||||
|         Config.http_enable = Config.config.get( Configuration.CATEGORY_GENERAL, "http_enable", http_enable ); | ||||
|         Config.http_enable.setComment( "Enable the \"http\" API on Computers (see \"http_whitelist\" for more fine grained control than this)" ); | ||||
|  | ||||
|         Config.http_whitelist = Config.config.get( Configuration.CATEGORY_GENERAL, "http_whitelist", http_whitelist ); | ||||
|         Config.http_whitelist.setComment( "A semicolon limited list of wildcards for domains that can be accessed through the \"http\" API on Computers. Set this to \"*\" to access to the entire internet. Example: \"*.pastebin.com;*.github.com;*.computercraft.info\" will restrict access to just those 3 domains." ); | ||||
|  | ||||
|         Config.disable_lua51_features = Config.config.get( Configuration.CATEGORY_GENERAL, "disable_lua51_features", disable_lua51_features ); | ||||
|         Config.disable_lua51_features.setComment( "Set this to true to disable Lua 5.1 functions that will be removed in a future update. Useful for ensuring forward compatibility of your programs now." ); | ||||
|  | ||||
|         Config.default_computer_settings = Config.config.get( Configuration.CATEGORY_GENERAL, "default_computer_settings", default_computer_settings ); | ||||
|         Config.default_computer_settings.setComment( "A comma seperated list of default system settings to set on new computers. Example: \"shell.autocomplete=false,lua.autocomplete=false,edit.autocomplete=false\" will disable all autocompletion" ); | ||||
|  | ||||
|         Config.enableCommandBlock = Config.config.get( Configuration.CATEGORY_GENERAL, "enableCommandBlock", enableCommandBlock ); | ||||
|         Config.enableCommandBlock.setComment( "Enable Command Block peripheral support" ); | ||||
|  | ||||
|         Config.modem_range = Config.config.get( Configuration.CATEGORY_GENERAL, "modem_range", modem_range ); | ||||
|         Config.modem_range.setComment( "The range of Wireless Modems at low altitude in clear weather, in meters" ); | ||||
|  | ||||
|         Config.modem_highAltitudeRange = Config.config.get( Configuration.CATEGORY_GENERAL, "modem_highAltitudeRange", modem_highAltitudeRange ); | ||||
|         Config.modem_highAltitudeRange.setComment( "The range of Wireless Modems at maximum altitude in clear weather, in meters" ); | ||||
|  | ||||
|         Config.modem_rangeDuringStorm = Config.config.get( Configuration.CATEGORY_GENERAL, "modem_rangeDuringStorm", modem_rangeDuringStorm ); | ||||
|         Config.modem_rangeDuringStorm.setComment( "The range of Wireless Modems at low altitude in stormy weather, in meters" ); | ||||
|  | ||||
|         Config.modem_highAltitudeRangeDuringStorm = Config.config.get( Configuration.CATEGORY_GENERAL, "modem_highAltitudeRangeDuringStorm", modem_highAltitudeRangeDuringStorm ); | ||||
|         Config.modem_highAltitudeRangeDuringStorm.setComment( "The range of Wireless Modems at maximum altitude in stormy weather, in meters" ); | ||||
|  | ||||
|         Config.computerSpaceLimit = Config.config.get( Configuration.CATEGORY_GENERAL, "computerSpaceLimit", computerSpaceLimit ); | ||||
|         Config.computerSpaceLimit.setComment( "The disk space limit for computers and turtles, in bytes" ); | ||||
|  | ||||
|         Config.floppySpaceLimit = Config.config.get( Configuration.CATEGORY_GENERAL, "floppySpaceLimit", floppySpaceLimit ); | ||||
|         Config.floppySpaceLimit.setComment( "The disk space limit for floppy disks, in bytes" ); | ||||
|  | ||||
|         Config.turtlesNeedFuel = Config.config.get( Configuration.CATEGORY_GENERAL, "turtlesNeedFuel", turtlesNeedFuel ); | ||||
|         Config.turtlesNeedFuel.setComment( "Set whether Turtles require fuel to move" ); | ||||
|  | ||||
|         Config.turtleFuelLimit = Config.config.get( Configuration.CATEGORY_GENERAL, "turtleFuelLimit", turtleFuelLimit ); | ||||
|         Config.turtleFuelLimit.setComment( "The fuel limit for Turtles" ); | ||||
|  | ||||
|         Config.advancedTurtleFuelLimit = Config.config.get( Configuration.CATEGORY_GENERAL, "advancedTurtleFuelLimit", advancedTurtleFuelLimit ); | ||||
|         Config.advancedTurtleFuelLimit.setComment( "The fuel limit for Advanced Turtles" ); | ||||
|  | ||||
|         Config.turtlesObeyBlockProtection = Config.config.get( Configuration.CATEGORY_GENERAL, "turtlesObeyBlockProtection", turtlesObeyBlockProtection ); | ||||
|         Config.turtlesObeyBlockProtection.setComment( "If set to true, Turtles will be unable to build, dig, or enter protected areas (such as near the server spawn point)" ); | ||||
|  | ||||
|         Config.turtlesCanPush = Config.config.get( Configuration.CATEGORY_GENERAL, "turtlesCanPush", turtlesCanPush ); | ||||
|         Config.turtlesCanPush.setComment( "If set to true, Turtles will push entities out of the way instead of stopping if there is space to do so" ); | ||||
|  | ||||
|         for (Property property : Config.config.getCategory( Configuration.CATEGORY_GENERAL ).getOrderedValues()) | ||||
|         { | ||||
|             property.setLanguageKey( "gui.computercraft:config." + CaseFormat.LOWER_CAMEL.to( CaseFormat.LOWER_UNDERSCORE, property.getName() ) ); | ||||
|         } | ||||
|  | ||||
|         syncConfig(); | ||||
|  | ||||
| @@ -212,76 +288,29 @@ public class ComputerCraft | ||||
|     } | ||||
|  | ||||
|     public static void syncConfig() { | ||||
|         Property prop = config.get(Configuration.CATEGORY_GENERAL, "http_enable", http_enable); | ||||
|         prop.setComment( "Enable the \"http\" API on Computers (see \"http_whitelist\" for more fine grained control than this)" ); | ||||
|         http_enable = prop.getBoolean(http_enable); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "http_whitelist", http_whitelist ); | ||||
|         prop.setComment( "A semicolon limited list of wildcards for domains that can be accessed through the \"http\" API on Computers. Set this to \"*\" to access to the entire internet. Example: \"*.pastebin.com;*.github.com;*.computercraft.info\" will restrict access to just those 3 domains." ); | ||||
|         http_whitelist = prop.getString(); | ||||
|         http_enable = Config.http_enable.getBoolean(); | ||||
|         http_whitelist = Config.http_whitelist.getString(); | ||||
|         disable_lua51_features = Config.disable_lua51_features.getBoolean(); | ||||
|         default_computer_settings = Config.default_computer_settings.getString(); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "disable_lua51_features", disable_lua51_features ); | ||||
|         prop.setComment( "Set this to true to disable Lua 5.1 functions that will be removed in a future update. Useful for ensuring forward compatibility of your programs now." ); | ||||
|         disable_lua51_features = prop.getBoolean( disable_lua51_features ); | ||||
|         enableCommandBlock = Config.enableCommandBlock.getBoolean(); | ||||
|  | ||||
|         prop = config.get( Configuration.CATEGORY_GENERAL, "default_computer_settings", default_computer_settings ); | ||||
|         prop.setComment( "A comma seperated list of default system settings to set on new computers. Example: \"shell.autocomplete=false,lua.autocomplete=false,edit.autocomplete=false\" will disable all autocompletion" ); | ||||
|         default_computer_settings = prop.getString(); | ||||
|         modem_range = Math.min( Config.modem_range.getInt(), 100000 ); | ||||
|         modem_highAltitudeRange = Math.min( Config.modem_highAltitudeRange.getInt(), 100000 ); | ||||
|         modem_rangeDuringStorm = Math.min( Config.modem_rangeDuringStorm.getInt(), 100000 ); | ||||
|         modem_highAltitudeRangeDuringStorm = Math.min( Config.modem_highAltitudeRangeDuringStorm.getInt(), 100000 ); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "enableCommandBlock", enableCommandBlock); | ||||
|         prop.setComment( "Enable Command Block peripheral support" ); | ||||
|         enableCommandBlock = prop.getBoolean(enableCommandBlock); | ||||
|         computerSpaceLimit = Config.computerSpaceLimit.getInt(); | ||||
|         floppySpaceLimit = Config.floppySpaceLimit.getInt(); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "modem_range", modem_range); | ||||
|         prop.setComment( "The range of Wireless Modems at low altitude in clear weather, in meters" ); | ||||
|         modem_range = Math.min( prop.getInt(), 100000 ); | ||||
|         turtlesNeedFuel = Config.turtlesNeedFuel.getBoolean(); | ||||
|         turtleFuelLimit = Config.turtleFuelLimit.getInt(); | ||||
|         advancedTurtleFuelLimit = Config.advancedTurtleFuelLimit.getInt(); | ||||
|         turtlesObeyBlockProtection = Config.turtlesObeyBlockProtection.getBoolean(); | ||||
|         turtlesCanPush = Config.turtlesCanPush.getBoolean(); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "modem_highAltitudeRange", modem_highAltitudeRange); | ||||
|         prop.setComment( "The range of Wireless Modems at maximum altitude in clear weather, in meters" ); | ||||
|         modem_highAltitudeRange = Math.min( prop.getInt(), 100000 ); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "modem_rangeDuringStorm", modem_rangeDuringStorm); | ||||
|         prop.setComment( "The range of Wireless Modems at low altitude in stormy weather, in meters" ); | ||||
|         modem_rangeDuringStorm = Math.min( prop.getInt(), 100000 ); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "modem_highAltitudeRangeDuringStorm", modem_highAltitudeRangeDuringStorm); | ||||
|         prop.setComment( "The range of Wireless Modems at maximum altitude in stormy weather, in meters" ); | ||||
|         modem_highAltitudeRangeDuringStorm = Math.min( prop.getInt(), 100000 ); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "computerSpaceLimit", computerSpaceLimit); | ||||
|         prop.setComment( "The disk space limit for computers and turtles, in bytes" ); | ||||
|         computerSpaceLimit = prop.getInt(); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "floppySpaceLimit", floppySpaceLimit); | ||||
|         prop.setComment( "The disk space limit for floppy disks, in bytes" ); | ||||
|         floppySpaceLimit = prop.getInt(); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "turtlesNeedFuel", turtlesNeedFuel); | ||||
|         prop.setComment( "Set whether Turtles require fuel to move" ); | ||||
|         turtlesNeedFuel = prop.getBoolean( turtlesNeedFuel ); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "turtleFuelLimit", turtleFuelLimit); | ||||
|         prop.setComment( "The fuel limit for Turtles" ); | ||||
|         turtleFuelLimit = prop.getInt( turtleFuelLimit ); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "advancedTurtleFuelLimit", advancedTurtleFuelLimit); | ||||
|         prop.setComment( "The fuel limit for Advanced Turtles" ); | ||||
|         advancedTurtleFuelLimit = prop.getInt(advancedTurtleFuelLimit); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "turtlesObeyBlockProtection", turtlesObeyBlockProtection); | ||||
|         prop.setComment(  "If set to true, Turtles will be unable to build, dig, or enter protected areas (such as near the server spawn point)" ); | ||||
|         turtlesObeyBlockProtection = prop.getBoolean( turtlesObeyBlockProtection ); | ||||
|  | ||||
|         prop = config.get(Configuration.CATEGORY_GENERAL, "turtlesCanPush", turtlesCanPush); | ||||
|         prop.setComment( "If set to true, Turtles will push entities out of the way instead of stopping if there is space to do so" ); | ||||
|         turtlesCanPush = prop.getBoolean(turtlesCanPush); | ||||
|  | ||||
|         for (Property property : config.getCategory( Configuration.CATEGORY_GENERAL ).getOrderedValues()) | ||||
|         { | ||||
|             property.setLanguageKey( "gui.computercraft:config." + CaseFormat.LOWER_CAMEL.to( CaseFormat.LOWER_UNDERSCORE, property.getName() ) ); | ||||
|         } | ||||
|  | ||||
|         config.save(); | ||||
|         Config.config.save(); | ||||
|     } | ||||
|  | ||||
|     @Mod.EventHandler | ||||
|   | ||||
| @@ -24,7 +24,7 @@ public class GuiConfigCC extends GuiConfig | ||||
|     private static List<IConfigElement> getConfigElements() | ||||
|     { | ||||
|         ArrayList<IConfigElement> elements = new ArrayList<IConfigElement>(); | ||||
|         for (Property property : ComputerCraft.config.getCategory( Configuration.CATEGORY_GENERAL ).getOrderedValues()) | ||||
|         for (Property property : ComputerCraft.Config.config.getCategory( Configuration.CATEGORY_GENERAL ).getOrderedValues()) | ||||
|         { | ||||
|             elements.add( new ConfigElement( property ) ); | ||||
|         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 SquidDev
					SquidDev