10
0
mirror of https://gitlab.com/scemama/irpf90.git synced 2025-01-10 13:08:11 +01:00

Working on mangled entity

This commit is contained in:
Thomas Applencourt 2017-01-25 19:47:41 -06:00
parent dea0fccca5
commit 0e60db07ff
2 changed files with 13 additions and 6 deletions

View File

@ -167,6 +167,7 @@ class Entity(object):
if not self.is_main: if not self.is_main:
result = [] result = []
else: else:
from util import mangled
name = self.name name = self.name
result = [ \ result = [ \
"subroutine writer_%s(irp_num)"%(name), "subroutine writer_%s(irp_num)"%(name),
@ -184,7 +185,7 @@ class Entity(object):
" if (.not.%s_is_built) then"%(self.same_as), " if (.not.%s_is_built) then"%(self.same_as),
" call provide_%s"%(self.same_as), " call provide_%s"%(self.same_as),
" endif" ] " endif" ]
result += map(lambda x: " call writer_%s(irp_num)" % (x), self.needs) result += map(lambda x: " call writer_%s(irp_num)" % (x), mangles(self.needs))
result += [ \ result += [ \
" irp_is_open = .True.", " irp_is_open = .True.",
" irp_iunit = 9", " irp_iunit = 9",
@ -213,6 +214,7 @@ class Entity(object):
if not self.is_main: if not self.is_main:
result = [] result = []
else: else:
from util import mangled
name = self.name name = self.name
result = [ \ result = [ \
"subroutine reader_%s(irp_num)"%(name), "subroutine reader_%s(irp_num)"%(name),
@ -226,7 +228,7 @@ class Entity(object):
result += [\ result += [\
" character*(%d) :: irp_here = 'reader_%s'"%(length,name), " character*(%d) :: irp_here = 'reader_%s'"%(length,name),
" call irp_enter(irp_here)" ] " call irp_enter(irp_here)" ]
result += map(lambda x: " call reader_%s(irp_num)" % (x), self.needs) result += map(lambda x: " call reader_%s(irp_num)" % (x), mangled(self.needs))
result += [ \ result += [ \
" irp_is_open = .True.", " irp_is_open = .True.",
" irp_iunit = 9", " irp_iunit = 9",

View File

@ -285,6 +285,10 @@ def build_dim(l_dim, colons=False):
return "(%s)" % (",".join(l_dim_colons)) return "(%s)" % (",".join(l_dim_colons))
def mangled(l_ent, d_ent):
# (List, Dict[str,Entity]) -> list
'''Create a uniq list of provider'''
return OrderedUniqueList(d_ent[name].same_as for name in l_ent)
def build_use(l_ent, d_ent): def build_use(l_ent, d_ent):
# (List, Dict[str,Entity]) -> list # (List, Dict[str,Entity]) -> list
@ -294,12 +298,13 @@ def build_use(l_ent, d_ent):
def build_call_provide(l_ent, d_ent): def build_call_provide(l_ent, d_ent):
# (List, Dict[str,Entity]) -> list # (List, Dict[str,Entity]) -> list
'''Construct the fortran 90 call the provider needed by the list of entity''' '''Construct the fortran 90 call the provider needed by the list of entity'''
def fun(x):
# Get the corect name (in the case of multiple provider line)
l_same_as = mangled(l_ent,d_ent)
def bld_f90(x):
return [ " if (.not.%s_is_built) then" % x, return [ " if (.not.%s_is_built) then" % x,
" call provide_%s" % x, " call provide_%s" % x,
" endif"] " endif"]
# Get the corect name (in the case of multiple provider line) return flatten(map(bld_f90, l_same_as))
l_same_as = OrderedUniqueList(d_ent[x].same_as for x in l_ent)
return flatten(map(fun, l_same_as))