2018-04-27 14:33:57 +02:00
|
|
|
#!/usr/bin/env python2
|
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
|
2009-09-25 00:04:49 +02:00
|
|
|
# scemama@irsamc.ups-tlse.fr
|
2009-09-23 12:51:27 +02:00
|
|
|
|
2009-09-17 11:46:06 +02:00
|
|
|
|
|
|
|
from irpf90_t import *
|
|
|
|
from util import *
|
|
|
|
from variables import variables
|
2011-06-01 15:36:04 +02:00
|
|
|
from modules import modules
|
2009-09-17 11:46:06 +02:00
|
|
|
|
|
|
|
FILENAME=irpdir+'irp_touches.irp.F90'
|
|
|
|
|
|
|
|
def create():
|
|
|
|
out = []
|
|
|
|
l = variables.keys()
|
|
|
|
l.sort
|
2012-10-05 15:03:32 +02:00
|
|
|
main_modules = filter(lambda x: modules[x].is_main, modules)
|
2011-06-01 15:36:04 +02:00
|
|
|
finalize = "subroutine irp_finalize_%s\n"%(irp_id)
|
|
|
|
for m in filter(lambda x: not modules[x].is_main, modules):
|
|
|
|
finalize += " use %s\n"%(modules[m].name)
|
2009-09-17 11:46:06 +02:00
|
|
|
for v in l:
|
|
|
|
var = variables[v]
|
2012-10-05 15:03:32 +02:00
|
|
|
var_in_main = False
|
|
|
|
for m in main_modules:
|
|
|
|
if var.fmodule == modules[m].name:
|
|
|
|
var_in_main = True
|
|
|
|
break
|
|
|
|
if not var_in_main:
|
|
|
|
if var.is_touched:
|
|
|
|
out += var.toucher
|
|
|
|
if var.dim != []:
|
|
|
|
finalize += " if (allocated(%s)) then\n"%v
|
|
|
|
finalize += " %s_is_built = .False.\n"%var.same_as
|
|
|
|
finalize += " deallocate(%s)\n"%v
|
|
|
|
finalize += " endif\n"
|
2011-06-01 15:36:04 +02:00
|
|
|
finalize += "end\n"
|
|
|
|
|
2009-09-17 11:46:06 +02:00
|
|
|
|
2011-04-14 16:53:31 +02:00
|
|
|
if out != []:
|
|
|
|
out = map(lambda x: "%s\n"%(x),out)
|
2011-06-01 15:36:04 +02:00
|
|
|
|
|
|
|
out += finalize
|
|
|
|
|
2011-05-16 16:55:11 +02:00
|
|
|
if not same_file(FILENAME,out):
|
2009-09-17 11:46:06 +02:00
|
|
|
file = open(FILENAME,'w')
|
|
|
|
file.writelines(out)
|
|
|
|
file.close()
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
create()
|
|
|
|
|