Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

(Closes #2642, initial step towards #2643) Implement extends(type), procedure in derived type, class in declarations. #2644

Open
wants to merge 28 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
a527543
Add `type, extends` and `procedure` support in `StructureType`.
JulienRemy Jun 25, 2024
b95abdc
Add support for `class` keyword in declarations.
JulienRemy Jul 1, 2024
349bd2b
Cleanup.
JulienRemy Jul 2, 2024
f3bb061
#2642 Implement `extends`, `procedure` in derived types, `class` keyw…
JulienRemy Jul 2, 2024
db3d952
#2642 Add missing `class` keyword in Fortran backend.
JulienRemy Jul 15, 2024
6d0bb74
#2642 Fix `replace` calls for #2643 workaround.
JulienRemy Jul 15, 2024
a449c31
Merge branch 'master' into 2642_implement_extends_procedure_and_class
Nov 28, 2024
16ed2e4
#2642 Fix flake8 formatting and some tests.
Nov 28, 2024
e182c18
#2642 Some codecov progress, some tests still missing.
Nov 28, 2024
ff993ea
Merge branch 'master' into 2642_implement_extends_procedure_and_class
Nov 28, 2024
8c789b7
#2642 More tests.
Nov 29, 2024
4247a00
Merge branch 'master' into 2642_implement_extends_procedure_and_class
Nov 29, 2024
1cd37e4
#2642 Edit dev doc
Nov 29, 2024
0719559
#2642 Cleanup
Nov 29, 2024
6698427
#2642 More codecov
Nov 29, 2024
cc6fb67
#2642 Flake8
Nov 29, 2024
c8f74cb
#2642 Remove nonsensical test. Edit psyGen w.r.t. procedure support.
Dec 2, 2024
c35d98b
#2642 Avoid useless extends DataTypeSymbol visibility and procedure d…
Dec 2, 2024
0923123
Merge branch 'master' into 2642_implement_extends_procedure_and_class
Dec 2, 2024
18679fa
#2642 Add test about unkown parent type not being declared in the mod…
Dec 2, 2024
706bffc
#2642 Add psyGen tests and cleanup.
Dec 2, 2024
b72336b
#2642 Edits w.r.t. Andy's review
Dec 11, 2024
809ebf2
#2642 codecov
Dec 11, 2024
6f18710
#2642 flake8...
Dec 11, 2024
9419a05
#2642 Refactor, codecov
Dec 11, 2024
421e546
Merge branch 'master' into 2642_implement_extends_procedure_and_class
arporter Dec 18, 2024
a862a21
#2642 Fix parent type to UnresolvedInterface and add to symbol table.
Dec 18, 2024
cbc5857
#2642 Edits wrt Andy's second review (all except `class(*)`)
Dec 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
52 changes: 26 additions & 26 deletions src/psyclone/domain/lfric/kernel/lfric_kernel_metadata.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,40 +44,40 @@
from fparser.two.utils import walk, get_child

from psyclone.domain.lfric import LFRicConstants
from psyclone.domain.lfric.kernel.columnwise_operator_arg_metadata import \
ColumnwiseOperatorArgMetadata
from psyclone.domain.lfric.kernel.columnwise_operator_arg_metadata import (
ColumnwiseOperatorArgMetadata)
from psyclone.domain.lfric.kernel.field_arg_metadata import FieldArgMetadata
from psyclone.domain.lfric.kernel.field_vector_arg_metadata import \
FieldVectorArgMetadata
from psyclone.domain.lfric.kernel.inter_grid_arg_metadata import \
InterGridArgMetadata
from psyclone.domain.lfric.kernel.inter_grid_vector_arg_metadata import \
InterGridVectorArgMetadata
from psyclone.domain.lfric.kernel.operator_arg_metadata import \
OperatorArgMetadata
from psyclone.domain.lfric.kernel.field_vector_arg_metadata import (
FieldVectorArgMetadata)
from psyclone.domain.lfric.kernel.inter_grid_arg_metadata import (
InterGridArgMetadata)
from psyclone.domain.lfric.kernel.inter_grid_vector_arg_metadata import (
InterGridVectorArgMetadata)
from psyclone.domain.lfric.kernel.operator_arg_metadata import (
OperatorArgMetadata)
from psyclone.domain.lfric.kernel.common_metadata import CommonMetadata
from psyclone.domain.lfric.kernel.common_meta_arg_metadata import \
CommonMetaArgMetadata
from psyclone.domain.lfric.kernel.evaluator_targets_metadata import \
EvaluatorTargetsMetadata
from psyclone.domain.lfric.kernel.meta_args_metadata import \
MetaArgsMetadata
from psyclone.domain.lfric.kernel.meta_funcs_metadata import \
MetaFuncsMetadata
from psyclone.domain.lfric.kernel.meta_mesh_metadata import \
MetaMeshMetadata
from psyclone.domain.lfric.kernel.meta_ref_element_metadata import \
MetaRefElementMetadata
from psyclone.domain.lfric.kernel.operates_on_metadata import \
OperatesOnMetadata
from psyclone.domain.lfric.kernel.common_meta_arg_metadata import (
CommonMetaArgMetadata)
from psyclone.domain.lfric.kernel.evaluator_targets_metadata import (
EvaluatorTargetsMetadata)
from psyclone.domain.lfric.kernel.meta_args_metadata import (
MetaArgsMetadata)
from psyclone.domain.lfric.kernel.meta_funcs_metadata import (
MetaFuncsMetadata)
from psyclone.domain.lfric.kernel.meta_mesh_metadata import (
MetaMeshMetadata)
from psyclone.domain.lfric.kernel.meta_ref_element_metadata import (
MetaRefElementMetadata)
from psyclone.domain.lfric.kernel.operates_on_metadata import (
OperatesOnMetadata)
from psyclone.domain.lfric.kernel.scalar_arg_metadata import ScalarArgMetadata
from psyclone.domain.lfric.kernel.shapes_metadata import ShapesMetadata
from psyclone.errors import InternalError
from psyclone.parse.utils import ParseError
from psyclone.psyir.frontend.fortran import FortranReader
from psyclone.psyir.backend.fortran import FortranWriter
from psyclone.psyir.symbols import DataTypeSymbol, UnsupportedFortranType, \
StructureType
from psyclone.psyir.symbols import (DataTypeSymbol, UnsupportedFortranType,
StructureType)

# pylint: disable=too-many-lines
# pylint: disable=too-many-instance-attributes
Expand Down
45 changes: 7 additions & 38 deletions src/psyclone/psyGen.py
Original file line number Diff line number Diff line change
Expand Up @@ -1765,45 +1765,14 @@ def _rename_psyir(self, suffix):
partial_datatype=sym.datatype.partial_datatype)
# pylint: enable=protected-access
# Or the DataTypeSymbol is a StructureType, in which case we
# go through its procedure components.
# replace the "code" procedure component initial value.
elif isinstance(sym.datatype, StructureType):
arporter marked this conversation as resolved.
Show resolved Hide resolved
for procedure_name, procedure_component \
in sym.datatype.procedure_components.items():
# Either the procedure component is of
# UnsupportedFortranType, in which case we replace in its
# whole declaration.
if isinstance(procedure_component.datatype,
UnsupportedFortranType):
new_declaration = \
procedure_component.datatype.declaration.replace(
orig_kern_name, new_kern_name)
new_procedure_component = StructureType.ComponentType(
procedure_component.name,
UnsupportedFortranType(new_declaration,
procedure_component.
datatype.partial_datatype),
procedure_component.visibility,
procedure_component.initial_value)
sym.datatype.procedure_components[procedure_name] = \
new_procedure_component
# Or the procedure component has an initial value that is
# a Reference to the original kernel name, in which case
# we replace it with a Reference to the new kernel name.
elif (procedure_component.initial_value is not None
and (procedure_component.initial_value.name.lower()
== orig_kern_name.lower())):
new_kernel_symbol = RoutineSymbol(new_kern_name)
new_procedure_component = \
StructureType.ComponentType(procedure_component
.name,
procedure_component
.datatype,
procedure_component
.visibility,
Reference(
new_kernel_symbol))
sym.datatype.procedure_components[procedure_name] = \
new_procedure_component
new_kernel_symbol = container_table.lookup(new_kern_name)
new_initial_value = Reference(new_kernel_symbol)
sym.datatype.replace_procedure_component_initial_value(
orig_kern_name,
new_initial_value
)

@property
def modified(self):
Expand Down
2 changes: 1 addition & 1 deletion src/psyclone/psyad/domain/lfric/lfric_adjoint.py
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@
from psyclone.psyad import AdjointVisitor
from psyclone.psyad.domain.common import create_adjoint_name
from psyclone.psyir.nodes import Routine
from psyclone.psyir.symbols import (ContainerSymbol, StructureType)
from psyclone.psyir.symbols import ContainerSymbol, StructureType
from psyclone.psyir.symbols.symbol import ArgumentInterface, ImportInterface


Expand Down
7 changes: 4 additions & 3 deletions src/psyclone/psyir/backend/fortran.py
Original file line number Diff line number Diff line change
Expand Up @@ -1000,6 +1000,9 @@ def gen_decls(self, symbol_table, is_module_scope=False):
# We ignore all symbols with a PreprocessorInterface
if isinstance(sym.interface, PreprocessorInterface):
all_symbols.remove(sym)
# We remove the '*' symbol used in 'class(*) :: var'
if sym.name == "*":
all_symbols.remove(sym)

# If the symbol table contains any symbols with an
# UnresolvedInterface interface (they are not explicitly
Expand All @@ -1010,9 +1013,7 @@ def gen_decls(self, symbol_table, is_module_scope=False):
unresolved_symbols = []
for sym in all_symbols[:]:
if isinstance(sym.interface, UnresolvedInterface):
# Explicitly deal with '*' as in 'class(*) :: var'
if sym.name != "*":
unresolved_symbols.append(sym)
unresolved_symbols.append(sym)
all_symbols.remove(sym)
try:
internal_interface_symbol = symbol_table.lookup(
Expand Down
Loading
Loading