mirror of
https://gitlab.com/scemama/irpf90.git
synced 2025-01-05 10:58:51 +01:00
add support for WHERE statement
This commit is contained in:
parent
763278756b
commit
3032e754a7
@ -180,9 +180,15 @@ def create_build_compile(t, l_module, l_ext_modfile=[], ninja=True):
|
|||||||
# MOD name are not part of the standart.
|
# MOD name are not part of the standart.
|
||||||
|
|
||||||
needed_modules = [dress(x, in_root=True) for x in l_ext_modfile]
|
needed_modules = [dress(x, in_root=True) for x in l_ext_modfile]
|
||||||
needed_modules += [
|
|
||||||
"%s.irp.o" % (x.filename) for x in l_module if x.name in t.needed_modules_usr
|
# Expensive and stupid. We can create a dict to do the loockup only once
|
||||||
]
|
for m in t.needed_modules_usr:
|
||||||
|
for x in l_module:
|
||||||
|
if m in x.gen_mod and x.filename != t.filename:
|
||||||
|
needed_modules.append("%s.irp.o" % x.filename)
|
||||||
|
|
||||||
|
from util import uniquify
|
||||||
|
needed_modules = uniquify(needed_modules)
|
||||||
|
|
||||||
needed_modules_irp = [
|
needed_modules_irp = [
|
||||||
"%s.irp.module.o" % (x.filename) for x in l_module if x.name in t.needed_modules_irp
|
"%s.irp.module.o" % (x.filename) for x in l_module if x.name in t.needed_modules_irp
|
||||||
@ -200,12 +206,13 @@ def create_build_compile(t, l_module, l_ext_modfile=[], ninja=True):
|
|||||||
list_of_modules = ' '.join(map(dress, needed_modules))
|
list_of_modules = ' '.join(map(dress, needed_modules))
|
||||||
list_of_modules_irp = ' '.join(map(dress, needed_modules_irp))
|
list_of_modules_irp = ' '.join(map(dress, needed_modules_irp))
|
||||||
|
|
||||||
inline_module = True
|
inline_include = True
|
||||||
if not inline_module:
|
if not inline_include:
|
||||||
#Wrong name, this not work!
|
#Wrong name, this not work!
|
||||||
#list_of_includes = ' '.join(map(lambda x: dress(x, in_root=True), t.includes))
|
#list_of_includes = ' '.join(map(lambda x: dress(x, in_root=True), t.includes))
|
||||||
raise NotImplemented
|
raise NotImplemented
|
||||||
else:
|
else:
|
||||||
|
#The include have already by included
|
||||||
list_of_includes = ' '
|
list_of_includes = ' '
|
||||||
|
|
||||||
l_build = [
|
l_build = [
|
||||||
@ -283,24 +290,23 @@ def create_makefile(d_flags,d_var,irpf90_flags,ninja=True):
|
|||||||
'\n'.join("{0} = {1}".format(k, ' '.join(v)) for k, v in sorted(d_var.iteritems())),
|
'\n'.join("{0} = {1}".format(k, ' '.join(v)) for k, v in sorted(d_var.iteritems())),
|
||||||
'']
|
'']
|
||||||
|
|
||||||
result += [
|
result += [ r'# Dark magic below modify with caution!',
|
||||||
r'# Dark magic below modify with caution!',
|
r'# "You are Not Expected to Understand This"',
|
||||||
r'# "You are Not Expected to Understand This"',
|
r"# .",
|
||||||
r"# .",
|
r"# /^\ .",
|
||||||
r"# /^\ .",
|
r'# /\ "V",',
|
||||||
r'# /\ "V",',
|
r"# /__\ I O o",
|
||||||
r"# /__\ I O o",
|
r"# //..\\ I .",
|
||||||
r"# //..\\ I .",
|
r"# \].`[/ I",
|
||||||
r"# \].`[/ I",
|
r"# /l\/j\ (] . O",
|
||||||
r"# /l\/j\ (] . O",
|
r"# /. ~~ ,\/I .",
|
||||||
r"# /. ~~ ,\/I .",
|
r"# \\L__j^\/I o",
|
||||||
r"# \\L__j^\/I o",
|
r"# \/--v} I o .",
|
||||||
r"# \/--v} I o .",
|
r"# | | I _________",
|
||||||
r"# | | I _________",
|
r"# | | I c(` ')o",
|
||||||
r"# | | I c(` ')o",
|
r"# | l I \. ,/",
|
||||||
r"# | l I \. ,/",
|
r"# _/j L l\_! _//^---^\\_",
|
||||||
r"# _/j L l\_! _//^---^\\_",
|
r""]
|
||||||
r""]
|
|
||||||
|
|
||||||
result += ["",
|
result += ["",
|
||||||
"ifeq ($(BUILD_SYSTEM),ninja)",
|
"ifeq ($(BUILD_SYSTEM),ninja)",
|
||||||
@ -309,15 +315,15 @@ r""]
|
|||||||
"else ifeq ($(BUILD_SYSTEM),make)",
|
"else ifeq ($(BUILD_SYSTEM),make)",
|
||||||
"\tBUILD_FILE=IRPF90_temp/build.make",
|
"\tBUILD_FILE=IRPF90_temp/build.make",
|
||||||
"\tBUILD_SYSTEM += -j",
|
"\tBUILD_SYSTEM += -j",
|
||||||
"else",
|
"else",
|
||||||
"DUMMY:",
|
"DUMMY:",
|
||||||
"\t$(error 'Wrong BUILD_SYSTEM: $(BUILD_SYSTEM)')",
|
"\t$(error 'Wrong BUILD_SYSTEM: $(BUILD_SYSTEM)')",
|
||||||
"endif"]
|
"endif"]
|
||||||
|
|
||||||
result += ["",
|
result += ["",
|
||||||
"define run_and_touch",
|
"define run_and_touch",
|
||||||
" $(BUILD_SYSTEM) -C $(dir $(1) ) -f $(notdir $(1) ) $(addprefix $(CURDIR)/, $(2)) && touch $(2)",
|
" $(BUILD_SYSTEM) -C $(dir $(1) ) -f $(notdir $(1) ) $(addprefix $(CURDIR)/, $(2)) && touch $(2)",
|
||||||
"endef",
|
"endef",
|
||||||
"",
|
"",
|
||||||
"EXE := $(shell egrep -ri '^\s*program' *.irp.f | cut -d'.' -f1)",
|
"EXE := $(shell egrep -ri '^\s*program' *.irp.f | cut -d'.' -f1)",
|
||||||
"",
|
"",
|
||||||
|
@ -75,8 +75,8 @@ l_type = [
|
|||||||
"Assert", "Touch", "SoftTouch", "Irp_read", "Irp_write", "Irp_If",
|
"Assert", "Touch", "SoftTouch", "Irp_read", "Irp_write", "Irp_If",
|
||||||
"Irp_Else", "Irp_Endif", "Openmp", "Directive", "Use", "Do", "Enddo", "If",
|
"Irp_Else", "Irp_Endif", "Openmp", "Directive", "Use", "Do", "Enddo", "If",
|
||||||
"Elseif", "Else", "Endif", "Select", "Case", "End_select", "Provide", "NoDep", "Return", "Include",
|
"Elseif", "Else", "Endif", "Select", "Case", "End_select", "Provide", "NoDep", "Return", "Include",
|
||||||
"Implicit", "Free", "End", "Provide_all","Contains",'Type','End_module','Interface','End_interface'
|
"Implicit", "Free", "End", "Provide_all","Contains",'Type','End_module','Interface','End_interface',
|
||||||
]
|
'Where','Elsewhere','Endwhere']
|
||||||
|
|
||||||
for t in l_type:
|
for t in l_type:
|
||||||
globals()[t] = type(t, (Line, ), {})
|
globals()[t] = type(t, (Line, ), {})
|
||||||
|
@ -155,11 +155,15 @@ class Fmodule(object):
|
|||||||
result = []
|
result = []
|
||||||
dec = []
|
dec = []
|
||||||
use = []
|
use = []
|
||||||
|
module = []
|
||||||
|
|
||||||
for vars, line in text:
|
for vars, line in text:
|
||||||
if isinstance(line, (Subroutine, Function, Program,Interface,Module)):
|
if isinstance(line, (Subroutine, Function, Program,Interface,Module)):
|
||||||
inside += 1
|
inside += 1
|
||||||
|
|
||||||
|
if type(line) == Module:
|
||||||
|
module.append((vars,line))
|
||||||
|
|
||||||
if inside:
|
if inside:
|
||||||
result.append((vars, line))
|
result.append((vars, line))
|
||||||
else:
|
else:
|
||||||
@ -168,6 +172,7 @@ class Fmodule(object):
|
|||||||
elif type(line) == Declaration:
|
elif type(line) == Declaration:
|
||||||
dec.append((vars, line))
|
dec.append((vars, line))
|
||||||
|
|
||||||
|
|
||||||
if isinstance(line,(End,End_interface,End_module)):
|
if isinstance(line,(End,End_interface,End_module)):
|
||||||
inside += -1
|
inside += -1
|
||||||
|
|
||||||
@ -175,13 +180,13 @@ class Fmodule(object):
|
|||||||
print 'Something wrong append'
|
print 'Something wrong append'
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
return use, dec, result
|
return use, module, dec, result
|
||||||
|
|
||||||
result = remove_providers(self.text)
|
result = remove_providers(self.text)
|
||||||
result = modify_functions(result)
|
result = modify_functions(result)
|
||||||
|
|
||||||
from collections import namedtuple
|
from collections import namedtuple
|
||||||
Residual_text_use_dec = namedtuple('Residual_text_use_dec', ['use', 'dec', 'result'])
|
Residual_text_use_dec = namedtuple('Residual_text_use_dec', ['use', 'module', 'dec', 'result'])
|
||||||
|
|
||||||
return Residual_text_use_dec(*extract_use_dec_text(result))
|
return Residual_text_use_dec(*extract_use_dec_text(result))
|
||||||
|
|
||||||
@ -189,6 +194,11 @@ class Fmodule(object):
|
|||||||
def use(self):
|
def use(self):
|
||||||
return set(" %s" % line.text for _, line in self.residual_text_use_dec.use)
|
return set(" %s" % line.text for _, line in self.residual_text_use_dec.use)
|
||||||
|
|
||||||
|
@irpy.lazy_property
|
||||||
|
def gen_mod(self):
|
||||||
|
'''List of module generated by the user in this module...'''
|
||||||
|
return set("%s" % line.subname for _, line in self.residual_text_use_dec.module)
|
||||||
|
|
||||||
@irpy.lazy_property
|
@irpy.lazy_property
|
||||||
def dec(self):
|
def dec(self):
|
||||||
'''The declaration of this module
|
'''The declaration of this module
|
||||||
@ -230,8 +240,7 @@ class Fmodule(object):
|
|||||||
|
|
||||||
@irpy.lazy_property
|
@irpy.lazy_property
|
||||||
def needed_modules(self):
|
def needed_modules(self):
|
||||||
l = set(x.split()[1] for x in self.generated_text + self.head + self.residual_text
|
l = set(x.split(',only').pop(0).split()[1] for x in self.generated_text + self.head + self.residual_text if x.lstrip().startswith("use "))
|
||||||
if x.lstrip().startswith("use "))
|
|
||||||
|
|
||||||
if self.name in l:
|
if self.name in l:
|
||||||
l.remove(self.name)
|
l.remove(self.name)
|
||||||
|
@ -34,6 +34,8 @@ import sys
|
|||||||
re_endif = re.compile("end +if")
|
re_endif = re.compile("end +if")
|
||||||
re_elseif = re.compile("else +if")
|
re_elseif = re.compile("else +if")
|
||||||
re_enddo = re.compile("end +do")
|
re_enddo = re.compile("end +do")
|
||||||
|
re_endwhere = re.compile("end +where")
|
||||||
|
|
||||||
re_endtype = re.compile("end +type.*")
|
re_endtype = re.compile("end +type.*")
|
||||||
re_endmodule = re.compile("end +module",re.I)
|
re_endmodule = re.compile("end +module",re.I)
|
||||||
re_endselect = re.compile("end +select")
|
re_endselect = re.compile("end +select")
|
||||||
@ -91,7 +93,10 @@ simple_dict = {
|
|||||||
"module": Module,
|
"module": Module,
|
||||||
"endmodule": End_module,
|
"endmodule": End_module,
|
||||||
"interface": Interface,
|
"interface": Interface,
|
||||||
"endinterface": End_interface
|
"endinterface": End_interface,
|
||||||
|
"where": Where,
|
||||||
|
"elsewhere": Elsewhere,
|
||||||
|
"endwhere": Endwhere,
|
||||||
}
|
}
|
||||||
|
|
||||||
def get_canonized_text(text_lower):
|
def get_canonized_text(text_lower):
|
||||||
@ -104,6 +109,7 @@ def get_canonized_text(text_lower):
|
|||||||
text_canonized = re_endif.sub("endif", text_canonized)
|
text_canonized = re_endif.sub("endif", text_canonized)
|
||||||
text_canonized = re_endselect.sub("endselect", text_canonized)
|
text_canonized = re_endselect.sub("endselect", text_canonized)
|
||||||
text_canonized = re_endinterface.sub("endinterface", text_canonized)
|
text_canonized = re_endinterface.sub("endinterface", text_canonized)
|
||||||
|
text_canonized = re_endwhere.sub('endwhere',text_canonized)
|
||||||
|
|
||||||
for c in """()'"[]""":
|
for c in """()'"[]""":
|
||||||
text_canonized = text_canonized.replace(c, " %s " % c)
|
text_canonized = text_canonized.replace(c, " %s " % c)
|
||||||
@ -422,7 +428,7 @@ def remove_comments(text, form):
|
|||||||
inside = False
|
inside = False
|
||||||
|
|
||||||
elif c == '!' and not inside:
|
elif c == '!' and not inside:
|
||||||
return str_[:i]
|
return str_[:i].strip()
|
||||||
|
|
||||||
return str_
|
return str_
|
||||||
|
|
||||||
@ -843,11 +849,16 @@ def check_begin_end(raw_text):
|
|||||||
n_end = len(d_type[t_end])
|
n_end = len(d_type[t_end])
|
||||||
n_begin = sum(len(d_type[t_begin]) for t_begin in l_begin)
|
n_begin = sum(len(d_type[t_begin]) for t_begin in l_begin)
|
||||||
|
|
||||||
|
if n_end != n_begin:
|
||||||
|
|
||||||
if n_end > n_begin:
|
if n_end > n_begin:
|
||||||
logger.error("You have more close statement than open statement (%s) (%s)",line.filename,t_end)
|
logger.error("You have more close statement than open statement (%s) (%s)",line.filename,t_end)
|
||||||
sys.exit(1)
|
else:
|
||||||
elif n_end < n_begin:
|
|
||||||
logger.error('You have more end statement than open statenemt for (%s) (%s)' % (line.filename, t_end))
|
logger.error('You have more end statement than open statenemt for (%s) (%s)' % (line.filename, t_end))
|
||||||
|
|
||||||
|
for i in zip([l for i in l_begin for l in d_type[i]], d_type[t_end]):
|
||||||
|
logger.debug(i)
|
||||||
|
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
######################################################################
|
######################################################################
|
||||||
|
Loading…
Reference in New Issue
Block a user