FLANG
InternalNames.h
1//===-- Optimizer/Support/InternalNames.h -----------------------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
9#ifndef FORTRAN_OPTIMIZER_SUPPORT_INTERNALNAMES_H
10#define FORTRAN_OPTIMIZER_SUPPORT_INTERNALNAMES_H
11
12#include "llvm/ADT/ArrayRef.h"
13#include "llvm/ADT/StringRef.h"
14#include <cstdint>
15#include <optional>
16
17namespace fir {
18
19static constexpr llvm::StringRef kNameSeparator = ".";
20static constexpr llvm::StringRef kBoundsSeparator = ".b.";
21static constexpr llvm::StringRef kComponentSeparator = ".c.";
22static constexpr llvm::StringRef kComponentInitSeparator = ".di.";
23static constexpr llvm::StringRef kDataPtrInitSeparator = ".dp.";
24static constexpr llvm::StringRef kTypeDescriptorSeparator = ".dt.";
25static constexpr llvm::StringRef kKindParameterSeparator = ".kp.";
26static constexpr llvm::StringRef kLenKindSeparator = ".lpk.";
27static constexpr llvm::StringRef kLenParameterSeparator = ".lv.";
28static constexpr llvm::StringRef kNameStringSeparator = ".n.";
29static constexpr llvm::StringRef kProcPtrSeparator = ".p.";
30static constexpr llvm::StringRef kSpecialBindingSeparator = ".s.";
31static constexpr llvm::StringRef kBindingTableSeparator = ".v.";
32static constexpr llvm::StringRef boxprocSuffix = "UnboxProc";
33
45 enum class IntrinsicType { CHARACTER, COMPLEX, INTEGER, LOGICAL, REAL };
46
48 enum class NameKind {
49 NOT_UNIQUED,
50 BLOCK_DATA_NAME,
51 COMMON,
52 CONSTANT,
53 DERIVED_TYPE,
54 DISPATCH_TABLE,
55 GENERATED,
56 INTRINSIC_TYPE_DESC,
57 NAMELIST_GROUP,
58 PROCEDURE,
59 TYPE_DESC,
60 VARIABLE
61 };
62
65 DeconstructedName(llvm::StringRef name) : name{name} {}
67 llvm::ArrayRef<std::string> procs, std::int64_t blockId,
68 llvm::StringRef name, llvm::ArrayRef<std::int64_t> kinds)
69 : modules{modules}, procs{procs}, blockId{blockId}, name{name},
70 kinds{kinds} {}
71
74 std::int64_t blockId;
75 std::string name;
77 };
78
80 static std::string doCommonBlock(llvm::StringRef name);
81
83 static std::string doConstant(llvm::ArrayRef<llvm::StringRef> modules,
85 std::int64_t block, llvm::StringRef name);
86
88 static std::string doDispatchTable(llvm::ArrayRef<llvm::StringRef> modules,
90 std::int64_t block, llvm::StringRef name,
92
94 static std::string doGenerated(llvm::StringRef name);
96 static std::string doGenerated(llvm::ArrayRef<llvm::StringRef> modules,
98 std::int64_t blockId, llvm::StringRef name);
99
101 static std::string
104 std::int64_t block, IntrinsicType type,
105 std::int64_t kind);
106
108 static std::string doProcedure(llvm::ArrayRef<llvm::StringRef> modules,
110 llvm::StringRef name);
111
113 static std::string doType(llvm::ArrayRef<llvm::StringRef> modules,
115 std::int64_t block, llvm::StringRef name,
117
119 static std::string doTypeDescriptor(llvm::ArrayRef<llvm::StringRef> modules,
121 std::int64_t block, llvm::StringRef name,
123 static std::string doTypeDescriptor(llvm::ArrayRef<std::string> modules,
125 std::int64_t block, llvm::StringRef name,
127
130 static std::string doVariable(llvm::ArrayRef<llvm::StringRef> modules,
132 std::int64_t block, llvm::StringRef name);
133
135 static std::string doNamelistGroup(llvm::ArrayRef<llvm::StringRef> modules,
137 llvm::StringRef name);
138
141 static llvm::StringRef doProgramEntry();
142
144 static std::pair<NameKind, DeconstructedName>
145 deconstruct(llvm::StringRef uniquedName);
146
148 static bool isExternalFacingUniquedName(
149 const std::pair<NameKind, DeconstructedName> &deconstructResult);
150
152 static bool needExternalNameMangling(llvm::StringRef uniquedName);
153
155 static bool belongsToModule(llvm::StringRef uniquedName,
156 llvm::StringRef moduleName);
157
161 static std::string getTypeDescriptorName(llvm::StringRef mangledTypeName);
162
163 static std::string
164 getTypeDescriptorAssemblyName(llvm::StringRef mangledTypeName);
165
169 static std::string
170 getTypeDescriptorBindingTableName(llvm::StringRef mangledTypeName);
171
174 static std::string getComponentInitName(llvm::StringRef mangledTypeName,
175 llvm::StringRef componentName);
176
182 static llvm::StringRef
183 dropTypeConversionMarkers(llvm::StringRef mangledTypeName);
184
185 static std::string replaceSpecialSymbols(const std::string &name);
186
189 static bool isSpecialSymbol(llvm::StringRef name);
190
191private:
192 static std::string intAsString(std::int64_t i);
193 static std::string doKind(std::int64_t kind);
194 static std::string doKinds(llvm::ArrayRef<std::int64_t> kinds);
195 static std::string toLower(llvm::StringRef name);
196
197 NameUniquer() = delete;
198 NameUniquer(const NameUniquer &) = delete;
199 NameUniquer(NameUniquer &&) = delete;
200 NameUniquer &operator=(const NameUniquer &) = delete;
201};
202
203} // namespace fir
204
205#endif // FORTRAN_OPTIMIZER_SUPPORT_INTERNALNAMES_H
Definition: FIRType.h:77
Definition: OpenACC.h:20
Definition: AbstractConverter.h:31
Components of an unparsed unique name.
Definition: InternalNames.h:64
Definition: InternalNames.h:44
static llvm::StringRef dropTypeConversionMarkers(llvm::StringRef mangledTypeName)
Definition: InternalNames.cpp:405
static bool needExternalNameMangling(llvm::StringRef uniquedName)
Check whether the name should be re-mangle with external ABI convention.
Definition: InternalNames.cpp:337
static std::string doCommonBlock(llvm::StringRef name)
Unique a common block name.
Definition: InternalNames.cpp:107
static std::string doVariable(llvm::ArrayRef< llvm::StringRef > modules, llvm::ArrayRef< llvm::StringRef > procs, std::int64_t block, llvm::StringRef name)
Definition: InternalNames.cpp:221
static std::pair< NameKind, DeconstructedName > deconstruct(llvm::StringRef uniquedName)
Decompose uniquedName into the parse name, symbol type, and scope info.
Definition: InternalNames.cpp:247
static std::string doIntrinsicTypeDescriptor(llvm::ArrayRef< llvm::StringRef > modules, llvm::ArrayRef< llvm::StringRef > procs, std::int64_t block, IntrinsicType type, std::int64_t kind)
Unique an intrinsic type descriptor.
Definition: InternalNames.cpp:147
static std::string getTypeDescriptorBindingTableName(llvm::StringRef mangledTypeName)
Definition: InternalNames.cpp:390
static llvm::StringRef doProgramEntry()
Definition: InternalNames.cpp:240
static std::string doConstant(llvm::ArrayRef< llvm::StringRef > modules, llvm::ArrayRef< llvm::StringRef > procs, std::int64_t block, llvm::StringRef name)
Unique a (global) constant name.
Definition: InternalNames.cpp:112
static bool isExternalFacingUniquedName(const std::pair< NameKind, DeconstructedName > &deconstructResult)
Check if the name is an external facing name.
Definition: InternalNames.cpp:328
static std::string getComponentInitName(llvm::StringRef mangledTypeName, llvm::StringRef componentName)
Definition: InternalNames.cpp:396
static std::string doProcedure(llvm::ArrayRef< llvm::StringRef > modules, llvm::ArrayRef< llvm::StringRef > procs, llvm::StringRef name)
Unique a procedure name.
Definition: InternalNames.cpp:178
static std::string doTypeDescriptor(llvm::ArrayRef< llvm::StringRef > modules, llvm::ArrayRef< llvm::StringRef > procs, std::int64_t block, llvm::StringRef name, llvm::ArrayRef< std::int64_t > kinds)
Unique a (derived) type descriptor name.
Definition: InternalNames.cpp:199
static std::string doGenerated(llvm::StringRef name)
Unique a compiler generated name without scope context.
Definition: InternalNames.cpp:133
static bool belongsToModule(llvm::StringRef uniquedName, llvm::StringRef moduleName)
Does uniquedName belong to module moduleName?
Definition: InternalNames.cpp:343
static std::string doDispatchTable(llvm::ArrayRef< llvm::StringRef > modules, llvm::ArrayRef< llvm::StringRef > procs, std::int64_t block, llvm::StringRef name, llvm::ArrayRef< std::int64_t > kinds)
Unique a dispatch table name.
Definition: InternalNames.cpp:122
static bool isSpecialSymbol(llvm::StringRef name)
Definition: InternalNames.cpp:415
static std::string doNamelistGroup(llvm::ArrayRef< llvm::StringRef > modules, llvm::ArrayRef< llvm::StringRef > procs, llvm::StringRef name)
Unique a namelist group name.
Definition: InternalNames.cpp:231
NameKind
The sort of the unique name.
Definition: InternalNames.h:48
static std::string getTypeDescriptorName(llvm::StringRef mangledTypeName)
Definition: InternalNames.cpp:380
static std::string doType(llvm::ArrayRef< llvm::StringRef > modules, llvm::ArrayRef< llvm::StringRef > procs, std::int64_t block, llvm::StringRef name, llvm::ArrayRef< std::int64_t > kinds)
Unique a derived type name.
Definition: InternalNames.cpp:187