irpf90/src/variables.py

98 lines
3.1 KiB
Python
Raw Normal View History

2009-09-04 15:11:42 +02:00
#!/usr/bin/python
2009-09-23 12:51:27 +02:00
# IRPF90 is a Fortran90 preprocessor written in Python for programming using
# the Implicit Reference to Parameters (IRP) method.
# Copyright (C) 2009 Anthony SCEMAMA
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
#
# Anthony Scemama
# LCPQ - IRSAMC - CNRS
# Universite Paul Sabatier
# 118, route de Narbonne
# 31062 Toulouse Cedex 4
# scemama@irsamc.ups-tlse.fr
2009-09-23 12:51:27 +02:00
2009-09-04 15:11:42 +02:00
from variable import *
from irpf90_t import *
2009-12-09 09:42:36 +01:00
from command_line import command_line
2009-09-08 16:00:46 +02:00
from util import *
2009-09-04 15:11:42 +02:00
2009-09-08 16:00:46 +02:00
######################################################################
2009-09-04 15:11:42 +02:00
def create_variables():
from preprocessed_text import preprocessed_text
result = {}
2011-09-30 19:10:18 +02:00
icount = 0
2009-09-04 15:11:42 +02:00
for filename, text in preprocessed_text:
buffer = []
inside = False
for line in text:
2010-10-02 23:42:55 +02:00
if type(line) == Begin_provider:
2009-09-04 15:11:42 +02:00
inside = True
if inside:
buffer.append(line)
2010-10-02 23:42:55 +02:00
if type(line) == End_provider:
2009-09-04 15:11:42 +02:00
inside = False
2011-09-30 19:10:18 +02:00
icount += 1
v = Variable(buffer,icount)
2009-09-04 15:11:42 +02:00
result[v.name] = v
for other in v.others:
2011-09-30 19:10:18 +02:00
result[other] = Variable(buffer,icount,other)
2009-09-04 15:11:42 +02:00
buffer = []
return result
variables = create_variables()
2009-09-08 16:00:46 +02:00
######################################################################
def build_use(vars):
result = map(lambda x: " use %s"%(variables[x].fmodule), vars)
result = make_single(result)
return result
######################################################################
2009-09-14 14:36:39 +02:00
def call_provides(vars,opt=False):
2009-09-08 16:00:46 +02:00
vars = make_single( map(lambda x: variables[x].same_as, vars) )
2009-09-14 14:36:39 +02:00
if opt:
all_children = flatten( map(lambda x: variables[x].children, vars ))
vars = filter(lambda x: x not in all_children,vars)
2009-09-08 16:00:46 +02:00
def fun(x):
result = []
2009-12-09 09:42:36 +01:00
if command_line.do_openmp:
result += [ "!$OMP TASK" ]
result += [ \
" if (.not.%s_is_built) then"%(x) ]
result += [ \
" call provide_%s"%(x) ]
2009-12-09 09:42:36 +01:00
result += [ \
2009-09-08 16:00:46 +02:00
" endif" ]
2009-12-09 09:42:36 +01:00
if command_line.do_openmp:
result += [ "!$OMP END TASK" ]
return result
result = flatten ( map (fun, vars) )
if command_line.do_openmp and result != []:
result.reverse()
result.remove("!$OMP TASK")
result.remove("!$OMP END TASK")
result.reverse()
if "!$OMP TASK" in result:
result += [ "!$OMP TASKWAIT" ]
return result
2009-09-08 16:00:46 +02:00
######################################################################
2009-09-04 15:11:42 +02:00
if __name__ == '__main__':
for v in variables.keys():
print v