simplifying parsing of absolute path
This commit is contained in:
parent
196b0ef22f
commit
ba8d9b7062
|
@ -149,46 +149,20 @@ class Material():
|
||||||
line = line.split('#')[0].strip() # kill comments and extra whitespace
|
line = line.split('#')[0].strip() # kill comments and extra whitespace
|
||||||
line = line.split('/echo/')[0].strip() # remove '/echo/' tags
|
line = line.split('/echo/')[0].strip() # remove '/echo/' tags
|
||||||
line = line.lower() # be case insensitive
|
line = line.lower() # be case insensitive
|
||||||
|
print(line)
|
||||||
if line: # content survives...
|
if line: # content survives...
|
||||||
match_part = re_part.match(line.split()[0])
|
match_part = re_part.match(line)
|
||||||
if match_part: # found <part> separator
|
if match_part: # found <part> separator
|
||||||
active = (match_part.group(1) == part) # only active in <part>
|
active = (match_part.group(1) == part) # only active in <part>
|
||||||
continue
|
continue
|
||||||
if active:
|
if active:
|
||||||
match_sec = re_sec.match(line.split()[0])
|
match_sec = re_sec.match(line)
|
||||||
if match_sec: # found [section]
|
if match_sec: # found [section]
|
||||||
name_section = match_sec.group(1) # remember name ...
|
name_section = match_sec.group(1) # remember name ...
|
||||||
if '__order__' not in self.data[part]: self.data[part]['__order__'] = []
|
if '__order__' not in self.data[part]: self.data[part]['__order__'] = []
|
||||||
self.data[part]['__order__'].append(name_section) # ... and position
|
self.data[part]['__order__'].append(name_section) # ... and position
|
||||||
self.data[part][name_section] = {'__order__':[]}
|
self.data[part][name_section] = {'__order__':[]}
|
||||||
continue
|
continue
|
||||||
# This part accesses the data in the files mentioned in the curly brackets. For now the file should be present in the working folder
|
|
||||||
#trying to generalize the file and its location.
|
|
||||||
if line:
|
|
||||||
match_include = re_include.match(line.split()[0])
|
|
||||||
if match_include:
|
|
||||||
sub_file = match_include.group(1).split('/')[1] #get the file name which has to be opened to get the data
|
|
||||||
#code to search for file when it is located anywhere
|
|
||||||
path_file = os.environ['PATH']
|
|
||||||
path_file = path_file[:(path_file.find("DAMASK") + len("DAMASK"))]
|
|
||||||
for root, dirs, files in os.walk(path_file):
|
|
||||||
if sub_file in files:
|
|
||||||
target_path = os.path.join(root, sub_file) #this would give the path for the sub_file
|
|
||||||
with open(target_path,'r') as f1: #using the target_path to open the file
|
|
||||||
subdata = f1.readlines()
|
|
||||||
subdata = [a for a in subdata if a != '\n'] #removes '\n' elements from the list
|
|
||||||
if subdata:
|
|
||||||
for entry in subdata:
|
|
||||||
if sections == [] or name_section in sections: # respect subset
|
|
||||||
items = entry.split()
|
|
||||||
if items[0] not in self.data[part][name_section]: # first encounter of key?
|
|
||||||
self.data[part][name_section][items[0]] = [] # create item
|
|
||||||
self.data[part][name_section]['__order__'].append(items[0])
|
|
||||||
if items[0].startswith('(') and items[0].endswith(')'): # multiple "(key)"
|
|
||||||
self.data[part][name_section][items[0]].append(items[1:])
|
|
||||||
else: # plain key
|
|
||||||
self.data[part][name_section][items[0]] = items[1:]
|
|
||||||
continue
|
|
||||||
|
|
||||||
if sections == [] or name_section in sections: # respect subset
|
if sections == [] or name_section in sections: # respect subset
|
||||||
items = line.split()
|
items = line.split()
|
||||||
|
@ -201,24 +175,26 @@ class Material():
|
||||||
self.data[part][name_section][items[0]] = items[1:]
|
self.data[part][name_section][items[0]] = items[1:]
|
||||||
|
|
||||||
def read(self,file=None):
|
def read(self,file=None):
|
||||||
|
fileNames = [None] * 10
|
||||||
|
fileNames[0] = file
|
||||||
re_include = re.compile(r'^{(.+)}$') # pattern for include
|
re_include = re.compile(r'^{(.+)}$') # pattern for include
|
||||||
c = []
|
c = []
|
||||||
with open(file,'r') as f:
|
with open(file,'r') as f:
|
||||||
for entry in f:
|
for entry in f:
|
||||||
match_include = re_include.match(entry.split()[0])
|
if not entry.strip(): continue
|
||||||
if match_include:
|
match = re_include.match(entry.split()[0])
|
||||||
sub_file = match_include.group(1).split('/')[-1] #get the file name which has to be opened to get the data,
|
if match:
|
||||||
#code to search for file when it is located anywhere
|
if match.group(1).startswith('/'):
|
||||||
path_file = os.environ['PATH']
|
sub_file = match.group(1)
|
||||||
path_file = path_file[:(path_file.find("DAMASK") + len("DAMASK"))]
|
|
||||||
for root, dirs, files in os.walk(path_file):
|
|
||||||
if sub_file in files:
|
|
||||||
target_path = os.path.join(root, sub_file) #this would give the path for the sub_file
|
|
||||||
with open(target_path,'r') as f1: #using the target_path to open the file
|
|
||||||
for data in f1:
|
|
||||||
c = c.append(data)
|
|
||||||
else:
|
else:
|
||||||
c = c.append(entry)
|
pass
|
||||||
|
with open(sub_file,'r') as f1: #using the target_path to open the file
|
||||||
|
for l in f1.readlines(): c.append(l)
|
||||||
|
else:
|
||||||
|
c.append(entry)
|
||||||
|
|
||||||
|
for l in c:
|
||||||
|
print(l)
|
||||||
for p in self.parts:
|
for p in self.parts:
|
||||||
self.parse_data(part=p, content=c)
|
self.parse_data(part=p, content=c)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue