When a FINAL subroutine is being invoked for a discontiguous array, which can happen for INTENT(OUT) dummy arguments and for some left-hand side variables in intrinsic assignment statements, it may be the case that the subroutine being called was defined with a dummy argument that requires contiguous data. Extend the derived type descriptions used by the runtime to signify when a special procedure binding requires contiguity; set the flags accordingly; check them in the runtime support library, and, when necessary, use a temporary shallow copy of the finalized array data in the call to the final subroutine. Differential Revision: https://reviews.llvm.org/D156760
42 lines
1.4 KiB
C++
42 lines
1.4 KiB
C++
//===-- runtime/derived.h -------------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Internal runtime utilities for derived type operations.
|
|
|
|
#ifndef FORTRAN_RUNTIME_DERIVED_H_
|
|
#define FORTRAN_RUNTIME_DERIVED_H_
|
|
|
|
namespace Fortran::runtime::typeInfo {
|
|
class DerivedType;
|
|
}
|
|
|
|
namespace Fortran::runtime {
|
|
class Descriptor;
|
|
class Terminator;
|
|
|
|
// Perform default component initialization, allocate automatic components.
|
|
// Returns a STAT= code (0 when all's well).
|
|
int Initialize(const Descriptor &, const typeInfo::DerivedType &, Terminator &,
|
|
bool hasStat = false, const Descriptor *errMsg = nullptr);
|
|
|
|
// Call FINAL subroutines, if any
|
|
void Finalize(
|
|
const Descriptor &, const typeInfo::DerivedType &derived, Terminator *);
|
|
|
|
// Call FINAL subroutines, deallocate allocatable & automatic components.
|
|
// Does not deallocate the original descriptor.
|
|
void Destroy(const Descriptor &, bool finalize, const typeInfo::DerivedType &,
|
|
Terminator *);
|
|
|
|
// Return true if the passed descriptor is for a derived type
|
|
// entity that has a dynamic (allocatable, automatic) component.
|
|
bool HasDynamicComponent(const Descriptor &);
|
|
|
|
} // namespace Fortran::runtime
|
|
#endif // FORTRAN_RUNTIME_DERIVED_H_
|