modified config struct

This commit is contained in:
sanjayk03-dev
2024-07-08 22:54:11 +05:30
parent 49efa31281
commit 16d3898f7f
3 changed files with 49 additions and 48 deletions

View File

@@ -79,10 +79,31 @@ class Config(object):
def get(self, name, default = None):
return self.values.get(name, default)
# def set(self, name, default = None):
# self.log.info(f'name:{name} default:{default}')
# self.log.info(f'config: {repr(self)}')
def set(self, name, default = None):
config = self.ctrl.config
path = self.ctrl.get_path('config.json')
try:
if os.path.exists(path):
with open(path, 'r') as f: config_data = json.load(f)
else: config_data = {'version': self.version}
if name in config_data:
existing_value = config_data[name]
if isinstance(existing_value, dict) and isinstance(default, dict):
config_data[name] = {**existing_value, **default}
elif isinstance(existing_value, list) and isinstance(default, list):
config_data[name].extend(default)
elif isinstance(existing_value, list):
config_data[name].append(default)
else:
config_data[name] = default
else:
config_data[name] = default
config.save(config_data)
self.log.info('name:{} default:{}'.format(name, default))
except Exception: self.log.exception('Internal error: Failed to upgrade config')
def save(self, config):
self._upgrade(config)

View File

@@ -355,26 +355,10 @@ class Mach(Comm):
def optional_pause(self, enable = True):
self.ctrl.state.set('optional_pause', enable)
def save_config(self, axis, target):
config = self.ctrl.config
path = self.ctrl.get_path('config.json')
try:
if os.path.exists(path):
with open(path, 'r') as f: config_data = json.load(f)
else: config_data = {'version': self.version}
axes = config_data.setdefault('axes',{})
axes[axis]['abs'] = target
config.save(config_data)
self.mlog.info(f'done with config: {config_data}')
except Exception: self.log.exception('Internal error: Failed to upgrade config')
def set_position(self, axis, position):
axis = axis.lower()
state = self.ctrl.state
config = self.ctrl.config
if state.is_axis_homed(axis):
# If homed, change the offset rather than the absolute position
@@ -390,7 +374,9 @@ class Mach(Comm):
self.mlog.info('target ' + str(target))
self.mlog.info('state.get ' + str(state.get('offset_' + axis)))
state.set(axis + 'p', target)
self.save_config(axis, target)
axes = config.values.setdefault('axes',{})
axes[axis + 'p'] = target
config.set('axes', axes)
super().queue_command(Cmd.set_axis(axis, target))

View File

@@ -654,35 +654,29 @@
},
"axes": {
"x": {
"abs": {
"type": "string",
"default": "0"
"xp": {
"type": "int",
"default": 0
},
"off": {
"type": "string",
"default": "0"
}
"yp": {
"type": "int",
"default": 0
},
"y": {
"abs": {
"type": "string",
"default": "0"
"zp": {
"type": "int",
"default": 0
},
"off": {
"type": "string",
"default": "0"
}
"offset_x": {
"type": "int",
"default": 0
},
"z": {
"abs": {
"type": "string",
"default": "0"
"offset_y": {
"type": "int",
"default": 0
},
"off": {
"type": "string",
"default": "0"
}
"offset_z": {
"type": "int",
"default": 0
}
},