irpf90/src/touches.py

74 lines
2.2 KiB
Python
Raw Normal View History

2020-01-27 18:22:35 +01:00
#!/usr/bin/env python3
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-17 11:46:06 +02:00
2020-01-27 18:43:22 +01:00
from irpf90_t import *
from util import *
from variables import variables
from modules import modules
2009-09-17 11:46:06 +02:00
FILENAME=irpdir+'irp_touches.irp.F90'
def create():
out = []
2020-01-27 18:22:35 +01:00
l = list(variables.keys())
2009-09-17 11:46:06 +02:00
l.sort
2020-01-27 18:22:35 +01:00
main_modules = [x for x in modules if modules[x].is_main]
finalize = "subroutine irp_finalize_%s\n"%(irp_id)
2020-01-27 18:22:35 +01:00
for m in [x for x in modules if not modules[x].is_main]:
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"
finalize += "end\n"
2009-09-17 11:46:06 +02:00
if out != []:
2020-01-27 18:22:35 +01:00
out = ["%s\n"%(x) for x in out]
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()