From 071287c6f9975d02ce737511ce95f736de5e155c Mon Sep 17 00:00:00 2001 From: bn Date: Wed, 3 Jul 2024 17:33:56 +0200 Subject: [PATCH] Enhance graphics options parsing. Fix problem with multiples options like 'width=216.81pt,keepaspectratio=true' --- amc2moodle/amc2moodle/convert.py | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/amc2moodle/amc2moodle/convert.py b/amc2moodle/amc2moodle/convert.py index b427232..8f932a7 100755 --- a/amc2moodle/amc2moodle/convert.py +++ b/amc2moodle/amc2moodle/convert.py @@ -994,7 +994,7 @@ def _graphics(self): # conversion des notations d'alignement align = {'ltx_align_right': 'right', 'ltx_align_left': 'left', 'ltx_centering': 'center'} - + dimensions = ('width', 'height') for Ii in Ilist: try: img_name = Ii.attrib['candidates'].split(',')[-1] # get the last candidates @@ -1008,11 +1008,15 @@ def _graphics(self): img_align = Ii.attrib['class'] else: img_align = 'ltx_centering' # default value center ! - # try for option + # try for options if 'options' in Ii.attrib: img_options = Ii.attrib['options'] - img_size = img_options.split('=')[-1] # il reste pt, mais cela ne semble pas poser de pb - img_dim = img_options.split('=')[0] + # Convert options into a dict and select usefull key + img_options_dict = dict([s.split('=') for s in img_options.split(',')]) + for key, val in img_options_dict.items(): + if key in dimensions: + img_size = val # il reste pt, mais cela ne semble pas poser de pb + img_dim = key else: img_options = '' img_size = self.options['default_img_width']