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";
33static constexpr llvm::StringRef kDerivedTypeInitSuffix = "DerivedInit";
34
45struct NameUniquer {
46 enum class IntrinsicType { CHARACTER, COMPLEX, INTEGER, LOGICAL, REAL };
47
49 enum class NameKind {
50 NOT_UNIQUED,
51 BLOCK_DATA_NAME,
52 COMMON,
53 CONSTANT,
54 DERIVED_TYPE,
55 DISPATCH_TABLE,
56 GENERATED,
57 INTRINSIC_TYPE_DESC,
58 NAMELIST_GROUP,
59 PROCEDURE,
60 TYPE_DESC,
61 VARIABLE
62 };
63
65 struct DeconstructedName {
66 DeconstructedName(llvm::StringRef name) : name{name} {}
67 DeconstructedName(llvm::ArrayRef<std::string> modules,
68 llvm::ArrayRef<std::string> procs, std::int64_t blockId,
69 llvm::StringRef name, llvm::ArrayRef<std::int64_t> kinds)
70 : modules{modules}, procs{procs}, blockId{blockId}, name{name},
71 kinds{kinds} {}
72
75 std::int64_t blockId;
76 std::string name;
78 };
79
81 static std::string doCommonBlock(llvm::StringRef name);
82
84 static std::string doConstant(llvm::ArrayRef<llvm::StringRef> modules,
86 std::int64_t block, llvm::StringRef name);
87
89 static std::string doDispatchTable(llvm::ArrayRef<llvm::StringRef> modules,
91 std::int64_t block, llvm::StringRef name,
93
95 static std::string doGenerated(llvm::StringRef name);
97 static std::string doGenerated(llvm::ArrayRef<llvm::StringRef> modules,
99 std::int64_t blockId, llvm::StringRef name);
100
102 static std::string
105 std::int64_t block, IntrinsicType type,
106 std::int64_t kind);
107
109 static std::string doProcedure(llvm::ArrayRef<llvm::StringRef> modules,
111 llvm::StringRef name);
112
114 static std::string doType(llvm::ArrayRef<llvm::StringRef> modules,
116 std::int64_t block, llvm::StringRef name,
118
120 static std::string doTypeDescriptor(llvm::ArrayRef<llvm::StringRef> modules,
122 std::int64_t block, llvm::StringRef name,
124 static std::string doTypeDescriptor(llvm::ArrayRef<std::string> modules,
126 std::int64_t block, llvm::StringRef name,
128
131 static std::string doVariable(llvm::ArrayRef<llvm::StringRef> modules,
133 std::int64_t block, llvm::StringRef name);
134
136 static std::string doNamelistGroup(llvm::ArrayRef<llvm::StringRef> modules,
138 llvm::StringRef name);
139
142 static llvm::StringRef doProgramEntry();
143
145 static std::pair<NameKind, DeconstructedName>
146 deconstruct(llvm::StringRef uniquedName);
147
149 static bool isExternalFacingUniquedName(
150 const std::pair<NameKind, DeconstructedName> &deconstructResult);
151
153 static bool needExternalNameMangling(llvm::StringRef uniquedName);
154
156 static bool belongsToModule(llvm::StringRef uniquedName,
157 llvm::StringRef moduleName);
158
162 static std::string getTypeDescriptorName(llvm::StringRef mangledTypeName);
163
164 static std::string
165 getTypeDescriptorAssemblyName(llvm::StringRef mangledTypeName);
166
170 static std::string
171 getTypeDescriptorBindingTableName(llvm::StringRef mangledTypeName);
172
175 static std::string getComponentInitName(llvm::StringRef mangledTypeName,
176 llvm::StringRef componentName);
177
183 static llvm::StringRef
184 dropTypeConversionMarkers(llvm::StringRef mangledTypeName);
185
186 static std::string replaceSpecialSymbols(const std::string &name);
187
190 static bool isSpecialSymbol(llvm::StringRef name);
191
192private:
193 static std::string intAsString(std::int64_t i);
194 static std::string doKind(std::int64_t kind);
195 static std::string doKinds(llvm::ArrayRef<std::int64_t> kinds);
196 static std::string toLower(llvm::StringRef name);
197
198 NameUniquer() = delete;
199 NameUniquer(const NameUniquer &) = delete;
200 NameUniquer(NameUniquer &&) = delete;
201 NameUniquer &operator=(const NameUniquer &) = delete;
202};
203
204} // namespace fir
205
206#endif // FORTRAN_OPTIMIZER_SUPPORT_INTERNALNAMES_H
Definition FIRType.h:89
Definition OpenACC.h:20
Definition AbstractConverter.h:34
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:49
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