Python side: rework config system.

Load `terrain.conf` of the script directory by default.
Add a `terrain_higher.conf` for alternative terrain.
This commit is contained in:
Gael-de-Sailly 2020-11-14 12:19:40 +01:00
parent 8a15bc924d
commit c33f2d9582
4 changed files with 30 additions and 10 deletions

View File

@ -1,6 +1,11 @@
import os.path
def read_config_file(fname): def read_config_file(fname):
settings = {} settings = {}
if not os.path.isfile(fname):
return settings
with open(fname, 'r') as f: with open(fname, 'r') as f:
for line in f: for line in f:
slist = line.split('=', 1) slist = line.split('=', 1)

View File

@ -9,6 +9,7 @@ K = 1
m = 0.35 m = 0.35
d = 0.8 d = 0.8
sea_level = 0 sea_level = 0
flex_radius = 20
time = 10 time = 10
niter = 10 niter = 10

15
terrain_higher.conf Normal file
View File

@ -0,0 +1,15 @@
mapsize = 1000
scale = 400
vscale = 500
offset = 0
persistence = 0.65
lacunarity = 2.0
K = 0.5
m = 0.5
d = 0.1
sea_level = 0
flex_radius = 100
time = 10
niter = 10

View File

@ -15,29 +15,28 @@ import view_map
os.chdir(os.path.dirname(sys.argv[0])) os.chdir(os.path.dirname(sys.argv[0]))
argc = len(sys.argv) argc = len(sys.argv)
params = {} config_file = 'terrain.conf'
if argc > 1: if argc > 1:
if os.path.isfile(sys.argv[1]): config_file = sys.argv[1]
params = settings.read_config_file(sys.argv[1])
else: params = settings.read_config_file(config_file)
mapsize = int(sys.argv[1])
def get_setting(name, default): def get_setting(name, default):
if name in params: if name in params:
return params[name] return params[name]
return default return default
mapsize = int(get_setting('mapsize', 400)) mapsize = int(get_setting('mapsize', 1000))
scale = float(get_setting('scale', 200.0)) scale = float(get_setting('scale', 400.0))
vscale = float(get_setting('vscale', 200.0)) vscale = float(get_setting('vscale', 300.0))
offset = float(get_setting('offset', 0.0)) offset = float(get_setting('offset', 0.0))
persistence = float(get_setting('persistence', 0.5)) persistence = float(get_setting('persistence', 0.6))
lacunarity = float(get_setting('lacunarity', 2.0)) lacunarity = float(get_setting('lacunarity', 2.0))
K = float(get_setting('K', 1.0)) K = float(get_setting('K', 1.0))
m = float(get_setting('m', 0.35)) m = float(get_setting('m', 0.35))
d = float(get_setting('d', 1.0)) d = float(get_setting('d', 0.8))
sea_level = float(get_setting('sea_level', 0.0)) sea_level = float(get_setting('sea_level', 0.0))
flex_radius = float(get_setting('flex_radius', 20.0)) flex_radius = float(get_setting('flex_radius', 20.0))