[torque] replace name mangling with unique numbering
Name mangling is hard to get right and not easy to read. This CL replaces the remaining name mangling of types and generics with simpler names that are not always unique, but then fixes them up by appending a unique counter. For struct types, this required an @export annotation since we use some struct types in CSA. Drive-by-fixes: - Overwrite the copy constructor of Type to clear the list of alias names when creating a new type. - Change the existing append-a-number scheme to have different counters for each name. This the number of changed names when adding something and is more readable. Bug: v8:7793 Change-Id: Ied11ea1a251130f4562ddc0d81967368349e0bf6 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1866650 Commit-Queue: Tobias Tebbi <tebbi@chromium.org> Reviewed-by: Jakob Gruber <jgruber@chromium.org> Cr-Commit-Position: refs/heads/master@{#64449}
This commit is contained in:
parent
578d4a8ff7
commit
419b4e7ea5
@ -2,6 +2,7 @@
|
|||||||
// Use of this source code is governed by a BSD-style license that can be
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
@export
|
||||||
struct Arguments {
|
struct Arguments {
|
||||||
const frame: FrameWithArguments;
|
const frame: FrameWithArguments;
|
||||||
const base: RawPtr;
|
const base: RawPtr;
|
||||||
@ -14,6 +15,7 @@ extern macro GetFrameArguments(FrameWithArguments, intptr): Arguments;
|
|||||||
|
|
||||||
namespace arguments {
|
namespace arguments {
|
||||||
|
|
||||||
|
@export
|
||||||
struct ArgumentsInfo {
|
struct ArgumentsInfo {
|
||||||
frame: Frame;
|
frame: Frame;
|
||||||
argument_count: bint;
|
argument_count: bint;
|
||||||
|
@ -3708,6 +3708,7 @@ macro ConvertToRelativeIndex(indexNumber: Number, lengthIntPtr: intptr):
|
|||||||
extern builtin ObjectToString(Context, JSAny): JSAny;
|
extern builtin ObjectToString(Context, JSAny): JSAny;
|
||||||
extern builtin StringRepeat(Context, String, Number): String;
|
extern builtin StringRepeat(Context, String, Number): String;
|
||||||
|
|
||||||
|
@export
|
||||||
struct KeyValuePair {
|
struct KeyValuePair {
|
||||||
key: JSAny;
|
key: JSAny;
|
||||||
value: JSAny;
|
value: JSAny;
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
|
|
||||||
namespace iterator {
|
namespace iterator {
|
||||||
// Returned from IteratorBuiltinsAssembler::GetIterator().
|
// Returned from IteratorBuiltinsAssembler::GetIterator().
|
||||||
|
@export
|
||||||
struct IteratorRecord {
|
struct IteratorRecord {
|
||||||
// iteratorRecord.[[Iterator]]
|
// iteratorRecord.[[Iterator]]
|
||||||
object: JSReceiver;
|
object: JSReceiver;
|
||||||
|
@ -20,6 +20,7 @@ namespace typed_array {
|
|||||||
type BigUint64Elements;
|
type BigUint64Elements;
|
||||||
type BigInt64Elements;
|
type BigInt64Elements;
|
||||||
|
|
||||||
|
@export
|
||||||
struct TypedArrayElementsInfo {
|
struct TypedArrayElementsInfo {
|
||||||
// Calculates the number of bytes required for specified number of elements.
|
// Calculates the number of bytes required for specified number of elements.
|
||||||
CalculateByteLength(lengthSmi: PositiveSmi): uintptr labels IfInvalid {
|
CalculateByteLength(lengthSmi: PositiveSmi): uintptr labels IfInvalid {
|
||||||
|
@ -1061,14 +1061,16 @@ struct ExternConstDeclaration : Declaration {
|
|||||||
|
|
||||||
struct StructDeclaration : TypeDeclaration {
|
struct StructDeclaration : TypeDeclaration {
|
||||||
DEFINE_AST_NODE_LEAF_BOILERPLATE(StructDeclaration)
|
DEFINE_AST_NODE_LEAF_BOILERPLATE(StructDeclaration)
|
||||||
StructDeclaration(SourcePosition pos, Identifier* name,
|
StructDeclaration(SourcePosition pos, StructFlags flags, Identifier* name,
|
||||||
std::vector<Declaration*> methods,
|
std::vector<Declaration*> methods,
|
||||||
std::vector<StructFieldExpression> fields,
|
std::vector<StructFieldExpression> fields,
|
||||||
std::vector<Identifier*> generic_parameters)
|
std::vector<Identifier*> generic_parameters)
|
||||||
: TypeDeclaration(kKind, pos, name),
|
: TypeDeclaration(kKind, pos, name),
|
||||||
|
flags(flags),
|
||||||
methods(std::move(methods)),
|
methods(std::move(methods)),
|
||||||
fields(std::move(fields)),
|
fields(std::move(fields)),
|
||||||
generic_parameters(std::move(generic_parameters)) {}
|
generic_parameters(std::move(generic_parameters)) {}
|
||||||
|
StructFlags flags;
|
||||||
std::vector<Declaration*> methods;
|
std::vector<Declaration*> methods;
|
||||||
std::vector<StructFieldExpression> fields;
|
std::vector<StructFieldExpression> fields;
|
||||||
std::vector<Identifier*> generic_parameters;
|
std::vector<Identifier*> generic_parameters;
|
||||||
|
@ -106,6 +106,9 @@ enum class ClassFlag {
|
|||||||
};
|
};
|
||||||
using ClassFlags = base::Flags<ClassFlag>;
|
using ClassFlags = base::Flags<ClassFlag>;
|
||||||
|
|
||||||
|
enum class StructFlag { kNone = 0, kExport = 1 << 0 };
|
||||||
|
using StructFlags = base::Flags<StructFlag>;
|
||||||
|
|
||||||
} // namespace torque
|
} // namespace torque
|
||||||
} // namespace internal
|
} // namespace internal
|
||||||
} // namespace v8
|
} // namespace v8
|
||||||
|
@ -339,8 +339,9 @@ Callable* DeclarationVisitor::Specialize(
|
|||||||
Declarations::CreateIntrinsic(declaration->name->value, type_signature);
|
Declarations::CreateIntrinsic(declaration->name->value, type_signature);
|
||||||
} else {
|
} else {
|
||||||
BuiltinDeclaration* builtin = BuiltinDeclaration::cast(declaration);
|
BuiltinDeclaration* builtin = BuiltinDeclaration::cast(declaration);
|
||||||
callable = CreateBuiltin(builtin, generated_name, readable_name.str(),
|
callable =
|
||||||
type_signature, *body);
|
CreateBuiltin(builtin, GlobalContext::MakeUniqueName(generated_name),
|
||||||
|
readable_name.str(), type_signature, *body);
|
||||||
}
|
}
|
||||||
key.generic->specializations().Add(key.specialized_types, callable);
|
key.generic->specializations().Add(key.specialized_types, callable);
|
||||||
return callable;
|
return callable;
|
||||||
|
@ -168,9 +168,7 @@ TorqueMacro* Declarations::CreateTorqueMacro(std::string external_name,
|
|||||||
Signature signature,
|
Signature signature,
|
||||||
base::Optional<Statement*> body,
|
base::Optional<Statement*> body,
|
||||||
bool is_user_defined) {
|
bool is_user_defined) {
|
||||||
// TODO(tebbi): Switch to more predictable names to improve incremental
|
external_name = GlobalContext::MakeUniqueName(external_name);
|
||||||
// compilation.
|
|
||||||
external_name += "_" + std::to_string(GlobalContext::FreshId());
|
|
||||||
return RegisterDeclarable(std::unique_ptr<TorqueMacro>(new TorqueMacro(
|
return RegisterDeclarable(std::unique_ptr<TorqueMacro>(new TorqueMacro(
|
||||||
std::move(external_name), std::move(readable_name), std::move(signature),
|
std::move(external_name), std::move(readable_name), std::move(signature),
|
||||||
body, is_user_defined, exported_to_csa)));
|
body, is_user_defined, exported_to_csa)));
|
||||||
@ -215,10 +213,10 @@ Macro* Declarations::DeclareMacro(
|
|||||||
Method* Declarations::CreateMethod(AggregateType* container_type,
|
Method* Declarations::CreateMethod(AggregateType* container_type,
|
||||||
const std::string& name, Signature signature,
|
const std::string& name, Signature signature,
|
||||||
Statement* body) {
|
Statement* body) {
|
||||||
std::string generated_name{container_type->GetGeneratedMethodName(name)};
|
std::string generated_name = GlobalContext::MakeUniqueName(
|
||||||
Method* result = RegisterDeclarable(std::unique_ptr<Method>(
|
"Method_" + container_type->SimpleName() + "_" + name);
|
||||||
new Method(container_type, container_type->GetGeneratedMethodName(name),
|
Method* result = RegisterDeclarable(std::unique_ptr<Method>(new Method(
|
||||||
name, std::move(signature), body)));
|
container_type, generated_name, name, std::move(signature), body)));
|
||||||
container_type->RegisterMethod(result);
|
container_type->RegisterMethod(result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -274,8 +272,7 @@ NamespaceConstant* Declarations::DeclareNamespaceConstant(Identifier* name,
|
|||||||
const Type* type,
|
const Type* type,
|
||||||
Expression* body) {
|
Expression* body) {
|
||||||
CheckAlreadyDeclared<Value>(name->value, "constant");
|
CheckAlreadyDeclared<Value>(name->value, "constant");
|
||||||
std::string external_name =
|
std::string external_name = GlobalContext::MakeUniqueName(name->value);
|
||||||
name->value + "_" + std::to_string(GlobalContext::FreshId());
|
|
||||||
NamespaceConstant* result =
|
NamespaceConstant* result =
|
||||||
new NamespaceConstant(name, std::move(external_name), type, body);
|
new NamespaceConstant(name, std::move(external_name), type, body);
|
||||||
Declare(name->value, std::unique_ptr<Declarable>(result));
|
Declare(name->value, std::unique_ptr<Declarable>(result));
|
||||||
@ -297,8 +294,7 @@ std::string Declarations::GetGeneratedCallableName(
|
|||||||
const std::string& name, const TypeVector& specialized_types) {
|
const std::string& name, const TypeVector& specialized_types) {
|
||||||
std::string result = name;
|
std::string result = name;
|
||||||
for (auto type : specialized_types) {
|
for (auto type : specialized_types) {
|
||||||
std::string type_string = type->MangledName();
|
result += "_" + type->SimpleName();
|
||||||
result += std::to_string(type_string.size()) + type_string;
|
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -64,7 +64,9 @@ class GlobalContext : public ContextualClass<GlobalContext> {
|
|||||||
return Get().force_assert_statements_;
|
return Get().force_assert_statements_;
|
||||||
}
|
}
|
||||||
static Ast* ast() { return &Get().ast_; }
|
static Ast* ast() { return &Get().ast_; }
|
||||||
static size_t FreshId() { return Get().fresh_id_++; }
|
static std::string MakeUniqueName(const std::string& base) {
|
||||||
|
return base + "_" + std::to_string(Get().fresh_ids_[base]++);
|
||||||
|
}
|
||||||
|
|
||||||
struct PerFileStreams {
|
struct PerFileStreams {
|
||||||
std::stringstream csa_headerfile;
|
std::stringstream csa_headerfile;
|
||||||
@ -83,7 +85,7 @@ class GlobalContext : public ContextualClass<GlobalContext> {
|
|||||||
std::vector<std::string> cpp_includes_;
|
std::vector<std::string> cpp_includes_;
|
||||||
std::map<SourceId, PerFileStreams> generated_per_file_;
|
std::map<SourceId, PerFileStreams> generated_per_file_;
|
||||||
GlobalClassList classes_;
|
GlobalClassList classes_;
|
||||||
size_t fresh_id_ = 0;
|
std::map<std::string, size_t> fresh_ids_;
|
||||||
|
|
||||||
friend class LanguageServerData;
|
friend class LanguageServerData;
|
||||||
};
|
};
|
||||||
|
@ -873,6 +873,10 @@ base::Optional<ParseResult> MakeSpecializationDeclaration(
|
|||||||
|
|
||||||
base::Optional<ParseResult> MakeStructDeclaration(
|
base::Optional<ParseResult> MakeStructDeclaration(
|
||||||
ParseResultIterator* child_results) {
|
ParseResultIterator* child_results) {
|
||||||
|
bool is_export = child_results->NextAs<bool>();
|
||||||
|
StructFlags flags = StructFlag::kNone;
|
||||||
|
if (is_export) flags |= StructFlag::kExport;
|
||||||
|
|
||||||
auto name = child_results->NextAs<Identifier*>();
|
auto name = child_results->NextAs<Identifier*>();
|
||||||
if (!IsValidTypeName(name->value)) {
|
if (!IsValidTypeName(name->value)) {
|
||||||
NamingConventionError("Struct", name, "UpperCamelCase");
|
NamingConventionError("Struct", name, "UpperCamelCase");
|
||||||
@ -881,8 +885,8 @@ base::Optional<ParseResult> MakeStructDeclaration(
|
|||||||
LintGenericParameters(generic_parameters);
|
LintGenericParameters(generic_parameters);
|
||||||
auto methods = child_results->NextAs<std::vector<Declaration*>>();
|
auto methods = child_results->NextAs<std::vector<Declaration*>>();
|
||||||
auto fields = child_results->NextAs<std::vector<StructFieldExpression>>();
|
auto fields = child_results->NextAs<std::vector<StructFieldExpression>>();
|
||||||
Declaration* result =
|
Declaration* result = MakeNode<StructDeclaration>(
|
||||||
MakeNode<StructDeclaration>(name, std::move(methods), std::move(fields),
|
flags, name, std::move(methods), std::move(fields),
|
||||||
std::move(generic_parameters));
|
std::move(generic_parameters));
|
||||||
return ParseResult{result};
|
return ParseResult{result};
|
||||||
}
|
}
|
||||||
@ -1998,7 +2002,7 @@ struct TorqueGrammar : Grammar {
|
|||||||
Sequence({Token("generates"), &externalString})),
|
Sequence({Token("generates"), &externalString})),
|
||||||
&optionalClassBody},
|
&optionalClassBody},
|
||||||
AsSingletonVector<Declaration*, MakeClassDeclaration>()),
|
AsSingletonVector<Declaration*, MakeClassDeclaration>()),
|
||||||
Rule({Token("struct"), &name,
|
Rule({CheckIf(Token("@export")), Token("struct"), &name,
|
||||||
TryOrDefault<GenericParameters>(&genericParameters), Token("{"),
|
TryOrDefault<GenericParameters>(&genericParameters), Token("{"),
|
||||||
List<Declaration*>(&method),
|
List<Declaration*>(&method),
|
||||||
List<StructFieldExpression>(&structField), Token("}")},
|
List<StructFieldExpression>(&structField), Token("}")},
|
||||||
|
@ -265,6 +265,8 @@ class TypeOracle : public ContextualClass<TypeOracle> {
|
|||||||
|
|
||||||
static void FinalizeAggregateTypes();
|
static void FinalizeAggregateTypes();
|
||||||
|
|
||||||
|
static size_t FreshTypeId() { return Get().next_type_id_++; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
const Type* GetBuiltinType(const std::string& name) {
|
const Type* GetBuiltinType(const std::string& name) {
|
||||||
return Declarations::LookupGlobalType(name);
|
return Declarations::LookupGlobalType(name);
|
||||||
@ -277,6 +279,7 @@ class TypeOracle : public ContextualClass<TypeOracle> {
|
|||||||
std::vector<std::unique_ptr<AggregateType>> aggregate_types_;
|
std::vector<std::unique_ptr<AggregateType>> aggregate_types_;
|
||||||
std::vector<std::unique_ptr<Type>> top_types_;
|
std::vector<std::unique_ptr<Type>> top_types_;
|
||||||
std::vector<std::unique_ptr<Namespace>> struct_namespaces_;
|
std::vector<std::unique_ptr<Namespace>> struct_namespaces_;
|
||||||
|
size_t next_type_id_ = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace torque
|
} // namespace torque
|
||||||
|
@ -15,6 +15,15 @@ namespace v8 {
|
|||||||
namespace internal {
|
namespace internal {
|
||||||
namespace torque {
|
namespace torque {
|
||||||
|
|
||||||
|
// This custom copy constructor doesn't copy aliases_ and id_ because they
|
||||||
|
// should be distinct for each type.
|
||||||
|
Type::Type(const Type& other) V8_NOEXCEPT : TypeBase(other),
|
||||||
|
parent_(other.parent_),
|
||||||
|
aliases_(),
|
||||||
|
id_(TypeOracle::FreshTypeId()) {}
|
||||||
|
Type::Type(TypeBase::Kind kind, const Type* parent)
|
||||||
|
: TypeBase(kind), parent_(parent), id_(TypeOracle::FreshTypeId()) {}
|
||||||
|
|
||||||
std::string Type::ToString() const {
|
std::string Type::ToString() const {
|
||||||
if (aliases_.size() == 0) return ToExplicitString();
|
if (aliases_.size() == 0) return ToExplicitString();
|
||||||
if (aliases_.size() == 1) return *aliases_.begin();
|
if (aliases_.size() == 1) return *aliases_.begin();
|
||||||
@ -34,6 +43,11 @@ std::string Type::ToString() const {
|
|||||||
return result.str();
|
return result.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string Type::SimpleName() const {
|
||||||
|
if (aliases_.empty()) return SimpleNameImpl();
|
||||||
|
return *aliases_.begin();
|
||||||
|
}
|
||||||
|
|
||||||
bool Type::IsSubtypeOf(const Type* supertype) const {
|
bool Type::IsSubtypeOf(const Type* supertype) const {
|
||||||
if (supertype->IsTopType()) return true;
|
if (supertype->IsTopType()) return true;
|
||||||
if (IsNever()) return true;
|
if (IsNever()) return true;
|
||||||
@ -116,15 +130,13 @@ std::string BuiltinPointerType::ToExplicitString() const {
|
|||||||
return result.str();
|
return result.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string BuiltinPointerType::MangledName() const {
|
std::string BuiltinPointerType::SimpleNameImpl() const {
|
||||||
std::stringstream result;
|
std::stringstream result;
|
||||||
result << "FT";
|
result << "BuiltinPointer";
|
||||||
for (const Type* t : parameter_types_) {
|
for (const Type* t : parameter_types_) {
|
||||||
std::string arg_type_string = t->MangledName();
|
result << "_" << t->SimpleName();
|
||||||
result << arg_type_string.size() << arg_type_string;
|
|
||||||
}
|
}
|
||||||
std::string return_type_string = return_type_->MangledName();
|
result << "_" << return_type_->SimpleName();
|
||||||
result << return_type_string.size() << return_type_string;
|
|
||||||
return result.str();
|
return result.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -143,12 +155,15 @@ std::string UnionType::ToExplicitString() const {
|
|||||||
return result.str();
|
return result.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string UnionType::MangledName() const {
|
std::string UnionType::SimpleNameImpl() const {
|
||||||
std::stringstream result;
|
std::stringstream result;
|
||||||
result << "UT";
|
bool first = true;
|
||||||
for (const Type* t : types_) {
|
for (const Type* t : types_) {
|
||||||
std::string arg_type_string = t->MangledName();
|
if (!first) {
|
||||||
result << arg_type_string.size() << arg_type_string;
|
result << "_OR_";
|
||||||
|
}
|
||||||
|
first = false;
|
||||||
|
result << t->SimpleName();
|
||||||
}
|
}
|
||||||
return result.str();
|
return result.str();
|
||||||
}
|
}
|
||||||
@ -273,8 +288,22 @@ const Field& AggregateType::LookupField(const std::string& name) const {
|
|||||||
return LookupFieldInternal(name);
|
return LookupFieldInternal(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
StructType::StructType(Namespace* nspace, const StructDeclaration* decl,
|
||||||
|
MaybeSpecializationKey specialized_from)
|
||||||
|
: AggregateType(Kind::kStructType, nullptr, nspace,
|
||||||
|
ComputeName(decl->name->value, specialized_from)),
|
||||||
|
decl_(decl),
|
||||||
|
specialized_from_(specialized_from) {
|
||||||
|
if (decl->flags & StructFlag::kExport) {
|
||||||
|
generated_type_name_ = "TorqueStruct" + name();
|
||||||
|
} else {
|
||||||
|
generated_type_name_ =
|
||||||
|
GlobalContext::MakeUniqueName("TorqueStruct" + SimpleName());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
std::string StructType::GetGeneratedTypeNameImpl() const {
|
std::string StructType::GetGeneratedTypeNameImpl() const {
|
||||||
return "TorqueStruct" + MangledName();
|
return generated_type_name_;
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
@ -296,15 +325,12 @@ std::string StructType::ComputeName(
|
|||||||
return s.str();
|
return s.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string StructType::MangledName() const {
|
std::string StructType::SimpleNameImpl() const {
|
||||||
std::stringstream result;
|
std::stringstream result;
|
||||||
// TODO(gsps): Add 'ST' as a prefix once we can control the generated type
|
|
||||||
// name from Torque code
|
|
||||||
result << decl_->name->value;
|
result << decl_->name->value;
|
||||||
if (specialized_from_) {
|
if (specialized_from_) {
|
||||||
for (const Type* t : specialized_from_->specialized_types) {
|
for (const Type* t : specialized_from_->specialized_types) {
|
||||||
std::string arg_type_string = t->MangledName();
|
result << "_" << t->SimpleName();
|
||||||
result << arg_type_string.size() << arg_type_string;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return result.str();
|
return result.str();
|
||||||
@ -589,9 +615,7 @@ bool IsAssignableFrom(const Type* to, const Type* from) {
|
|||||||
return TypeOracle::IsImplicitlyConvertableFrom(to, from);
|
return TypeOracle::IsImplicitlyConvertableFrom(to, from);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool operator<(const Type& a, const Type& b) {
|
bool operator<(const Type& a, const Type& b) { return a.id() < b.id(); }
|
||||||
return a.MangledName() < b.MangledName();
|
|
||||||
}
|
|
||||||
|
|
||||||
VisitResult ProjectStructField(VisitResult structure,
|
VisitResult ProjectStructField(VisitResult structure,
|
||||||
const std::string& fieldname) {
|
const std::string& fieldname) {
|
||||||
|
@ -84,8 +84,13 @@ class V8_EXPORT_PRIVATE Type : public TypeBase {
|
|||||||
public:
|
public:
|
||||||
virtual bool IsSubtypeOf(const Type* supertype) const;
|
virtual bool IsSubtypeOf(const Type* supertype) const;
|
||||||
|
|
||||||
|
// Default rendering for error messages etc.
|
||||||
std::string ToString() const;
|
std::string ToString() const;
|
||||||
virtual std::string MangledName() const = 0;
|
|
||||||
|
// This name is not unique, but short and somewhat descriptive.
|
||||||
|
// Used for naming generated code.
|
||||||
|
virtual std::string SimpleName() const;
|
||||||
|
|
||||||
bool IsVoid() const { return IsAbstractName(VOID_TYPE_STRING); }
|
bool IsVoid() const { return IsAbstractName(VOID_TYPE_STRING); }
|
||||||
bool IsNever() const { return IsAbstractName(NEVER_TYPE_STRING); }
|
bool IsNever() const { return IsAbstractName(NEVER_TYPE_STRING); }
|
||||||
bool IsBool() const { return IsAbstractName(BOOL_TYPE_STRING); }
|
bool IsBool() const { return IsAbstractName(BOOL_TYPE_STRING); }
|
||||||
@ -106,16 +111,19 @@ class V8_EXPORT_PRIVATE Type : public TypeBase {
|
|||||||
virtual std::vector<std::string> GetRuntimeTypes() const { return {}; }
|
virtual std::vector<std::string> GetRuntimeTypes() const { return {}; }
|
||||||
static const Type* CommonSupertype(const Type* a, const Type* b);
|
static const Type* CommonSupertype(const Type* a, const Type* b);
|
||||||
void AddAlias(std::string alias) const { aliases_.insert(std::move(alias)); }
|
void AddAlias(std::string alias) const { aliases_.insert(std::move(alias)); }
|
||||||
|
size_t id() const { return id_; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
Type(TypeBase::Kind kind, const Type* parent)
|
Type(TypeBase::Kind kind, const Type* parent);
|
||||||
: TypeBase(kind), parent_(parent) {}
|
Type(const Type& other) V8_NOEXCEPT;
|
||||||
|
Type& operator=(const Type& other) = delete;
|
||||||
const Type* parent() const { return parent_; }
|
const Type* parent() const { return parent_; }
|
||||||
void set_parent(const Type* t) { parent_ = t; }
|
void set_parent(const Type* t) { parent_ = t; }
|
||||||
int Depth() const;
|
int Depth() const;
|
||||||
virtual std::string ToExplicitString() const = 0;
|
virtual std::string ToExplicitString() const = 0;
|
||||||
virtual std::string GetGeneratedTypeNameImpl() const = 0;
|
virtual std::string GetGeneratedTypeNameImpl() const = 0;
|
||||||
virtual std::string GetGeneratedTNodeTypeNameImpl() const = 0;
|
virtual std::string GetGeneratedTNodeTypeNameImpl() const = 0;
|
||||||
|
virtual std::string SimpleNameImpl() const = 0;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool IsAbstractName(const std::string& name) const;
|
bool IsAbstractName(const std::string& name) const;
|
||||||
@ -123,6 +131,7 @@ class V8_EXPORT_PRIVATE Type : public TypeBase {
|
|||||||
// If {parent_} is not nullptr, then this type is a subtype of {parent_}.
|
// If {parent_} is not nullptr, then this type is a subtype of {parent_}.
|
||||||
const Type* parent_;
|
const Type* parent_;
|
||||||
mutable std::set<std::string> aliases_;
|
mutable std::set<std::string> aliases_;
|
||||||
|
size_t id_;
|
||||||
};
|
};
|
||||||
|
|
||||||
using TypeVector = std::vector<const Type*>;
|
using TypeVector = std::vector<const Type*>;
|
||||||
@ -169,7 +178,6 @@ std::ostream& operator<<(std::ostream& os, const Field& name_and_type);
|
|||||||
class TopType final : public Type {
|
class TopType final : public Type {
|
||||||
public:
|
public:
|
||||||
DECLARE_TYPE_BOILERPLATE(TopType)
|
DECLARE_TYPE_BOILERPLATE(TopType)
|
||||||
std::string MangledName() const override { return "top"; }
|
|
||||||
std::string GetGeneratedTypeNameImpl() const override { UNREACHABLE(); }
|
std::string GetGeneratedTypeNameImpl() const override { UNREACHABLE(); }
|
||||||
std::string GetGeneratedTNodeTypeNameImpl() const override {
|
std::string GetGeneratedTNodeTypeNameImpl() const override {
|
||||||
return source_type_->GetGeneratedTNodeTypeName();
|
return source_type_->GetGeneratedTNodeTypeName();
|
||||||
@ -189,6 +197,8 @@ class TopType final : public Type {
|
|||||||
: Type(Kind::kTopType, nullptr),
|
: Type(Kind::kTopType, nullptr),
|
||||||
reason_(std::move(reason)),
|
reason_(std::move(reason)),
|
||||||
source_type_(source_type) {}
|
source_type_(source_type) {}
|
||||||
|
std::string SimpleNameImpl() const override { return "TopType"; }
|
||||||
|
|
||||||
std::string reason_;
|
std::string reason_;
|
||||||
const Type* source_type_;
|
const Type* source_type_;
|
||||||
};
|
};
|
||||||
@ -198,11 +208,6 @@ class AbstractType final : public Type {
|
|||||||
DECLARE_TYPE_BOILERPLATE(AbstractType)
|
DECLARE_TYPE_BOILERPLATE(AbstractType)
|
||||||
const std::string& name() const { return name_; }
|
const std::string& name() const { return name_; }
|
||||||
std::string ToExplicitString() const override { return name(); }
|
std::string ToExplicitString() const override { return name(); }
|
||||||
std::string MangledName() const override {
|
|
||||||
std::string str(name());
|
|
||||||
std::replace(str.begin(), str.end(), ' ', '_');
|
|
||||||
return "AT" + str;
|
|
||||||
}
|
|
||||||
std::string GetGeneratedTypeNameImpl() const override {
|
std::string GetGeneratedTypeNameImpl() const override {
|
||||||
return IsConstexpr() ? generated_type_ : "TNode<" + generated_type_ + ">";
|
return IsConstexpr() ? generated_type_ : "TNode<" + generated_type_ + ">";
|
||||||
}
|
}
|
||||||
@ -243,6 +248,12 @@ class AbstractType final : public Type {
|
|||||||
!non_constexpr_version->IsConstexpr());
|
!non_constexpr_version->IsConstexpr());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string SimpleNameImpl() const override {
|
||||||
|
if (IsConstexpr())
|
||||||
|
return "constexpr_" + NonConstexprVersion()->SimpleName();
|
||||||
|
return name();
|
||||||
|
}
|
||||||
|
|
||||||
void SetConstexprVersion(const AbstractType* type) const {
|
void SetConstexprVersion(const AbstractType* type) const {
|
||||||
DCHECK_EQ(GetConstexprName(name()), type->name());
|
DCHECK_EQ(GetConstexprName(name()), type->name());
|
||||||
constexpr_version_ = type;
|
constexpr_version_ = type;
|
||||||
@ -262,7 +273,6 @@ class V8_EXPORT_PRIVATE BuiltinPointerType final : public Type {
|
|||||||
public:
|
public:
|
||||||
DECLARE_TYPE_BOILERPLATE(BuiltinPointerType)
|
DECLARE_TYPE_BOILERPLATE(BuiltinPointerType)
|
||||||
std::string ToExplicitString() const override;
|
std::string ToExplicitString() const override;
|
||||||
std::string MangledName() const override;
|
|
||||||
std::string GetGeneratedTypeNameImpl() const override {
|
std::string GetGeneratedTypeNameImpl() const override {
|
||||||
return parent()->GetGeneratedTypeName();
|
return parent()->GetGeneratedTypeName();
|
||||||
}
|
}
|
||||||
@ -296,6 +306,7 @@ class V8_EXPORT_PRIVATE BuiltinPointerType final : public Type {
|
|||||||
parameter_types_(parameter_types),
|
parameter_types_(parameter_types),
|
||||||
return_type_(return_type),
|
return_type_(return_type),
|
||||||
function_pointer_type_id_(function_pointer_type_id) {}
|
function_pointer_type_id_(function_pointer_type_id) {}
|
||||||
|
std::string SimpleNameImpl() const override;
|
||||||
|
|
||||||
const TypeVector parameter_types_;
|
const TypeVector parameter_types_;
|
||||||
const Type* const return_type_;
|
const Type* const return_type_;
|
||||||
@ -312,8 +323,6 @@ struct TypeLess {
|
|||||||
class V8_EXPORT_PRIVATE UnionType final : public Type {
|
class V8_EXPORT_PRIVATE UnionType final : public Type {
|
||||||
public:
|
public:
|
||||||
DECLARE_TYPE_BOILERPLATE(UnionType)
|
DECLARE_TYPE_BOILERPLATE(UnionType)
|
||||||
std::string ToExplicitString() const override;
|
|
||||||
std::string MangledName() const override;
|
|
||||||
std::string GetGeneratedTypeNameImpl() const override {
|
std::string GetGeneratedTypeNameImpl() const override {
|
||||||
return "TNode<" + GetGeneratedTNodeTypeName() + ">";
|
return "TNode<" + GetGeneratedTNodeTypeName() + ">";
|
||||||
}
|
}
|
||||||
@ -376,6 +385,7 @@ class V8_EXPORT_PRIVATE UnionType final : public Type {
|
|||||||
types_.insert(t);
|
types_.insert(t);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
std::string ToExplicitString() const override;
|
||||||
|
|
||||||
void Subtract(const Type* t);
|
void Subtract(const Type* t);
|
||||||
|
|
||||||
@ -396,6 +406,7 @@ class V8_EXPORT_PRIVATE UnionType final : public Type {
|
|||||||
private:
|
private:
|
||||||
explicit UnionType(const Type* t) : Type(Kind::kUnionType, t), types_({t}) {}
|
explicit UnionType(const Type* t) : Type(Kind::kUnionType, t), types_({t}) {}
|
||||||
void RecomputeParent();
|
void RecomputeParent();
|
||||||
|
std::string SimpleNameImpl() const override;
|
||||||
|
|
||||||
std::set<const Type*, TypeLess> types_;
|
std::set<const Type*, TypeLess> types_;
|
||||||
};
|
};
|
||||||
@ -405,7 +416,6 @@ const Type* SubtractType(const Type* a, const Type* b);
|
|||||||
class AggregateType : public Type {
|
class AggregateType : public Type {
|
||||||
public:
|
public:
|
||||||
DECLARE_TYPE_BOILERPLATE(AggregateType)
|
DECLARE_TYPE_BOILERPLATE(AggregateType)
|
||||||
std::string MangledName() const override { return name_; }
|
|
||||||
std::string GetGeneratedTypeNameImpl() const override { UNREACHABLE(); }
|
std::string GetGeneratedTypeNameImpl() const override { UNREACHABLE(); }
|
||||||
std::string GetGeneratedTNodeTypeNameImpl() const override { UNREACHABLE(); }
|
std::string GetGeneratedTNodeTypeNameImpl() const override { UNREACHABLE(); }
|
||||||
|
|
||||||
@ -423,10 +433,6 @@ class AggregateType : public Type {
|
|||||||
const std::string& name() const { return name_; }
|
const std::string& name() const { return name_; }
|
||||||
Namespace* nspace() const { return namespace_; }
|
Namespace* nspace() const { return namespace_; }
|
||||||
|
|
||||||
std::string GetGeneratedMethodName(const std::string& name) const {
|
|
||||||
return "_method_" + name_ + "_" + name;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual const Field& RegisterField(Field field) {
|
virtual const Field& RegisterField(Field field) {
|
||||||
fields_.push_back(field);
|
fields_.push_back(field);
|
||||||
return fields_.back();
|
return fields_.back();
|
||||||
@ -453,6 +459,7 @@ class AggregateType : public Type {
|
|||||||
void CheckForDuplicateFields() const;
|
void CheckForDuplicateFields() const;
|
||||||
// Use this lookup if you do not want to trigger finalization on this type.
|
// Use this lookup if you do not want to trigger finalization on this type.
|
||||||
const Field& LookupFieldInternal(const std::string& name) const;
|
const Field& LookupFieldInternal(const std::string& name) const;
|
||||||
|
std::string SimpleNameImpl() const override { return name_; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
mutable bool is_finalized_;
|
mutable bool is_finalized_;
|
||||||
@ -471,9 +478,7 @@ class StructType final : public AggregateType {
|
|||||||
using MaybeSpecializationKey =
|
using MaybeSpecializationKey =
|
||||||
base::Optional<SpecializationKey<GenericStructType>>;
|
base::Optional<SpecializationKey<GenericStructType>>;
|
||||||
|
|
||||||
std::string ToExplicitString() const override;
|
|
||||||
std::string GetGeneratedTypeNameImpl() const override;
|
std::string GetGeneratedTypeNameImpl() const override;
|
||||||
std::string MangledName() const override;
|
|
||||||
const MaybeSpecializationKey& GetSpecializedFrom() const {
|
const MaybeSpecializationKey& GetSpecializedFrom() const {
|
||||||
return specialized_from_;
|
return specialized_from_;
|
||||||
}
|
}
|
||||||
@ -486,18 +491,17 @@ class StructType final : public AggregateType {
|
|||||||
private:
|
private:
|
||||||
friend class TypeOracle;
|
friend class TypeOracle;
|
||||||
StructType(Namespace* nspace, const StructDeclaration* decl,
|
StructType(Namespace* nspace, const StructDeclaration* decl,
|
||||||
MaybeSpecializationKey specialized_from = base::nullopt)
|
MaybeSpecializationKey specialized_from = base::nullopt);
|
||||||
: AggregateType(Kind::kStructType, nullptr, nspace,
|
|
||||||
ComputeName(decl->name->value, specialized_from)),
|
|
||||||
decl_(decl),
|
|
||||||
specialized_from_(specialized_from) {}
|
|
||||||
|
|
||||||
void Finalize() const override;
|
void Finalize() const override;
|
||||||
|
std::string ToExplicitString() const override;
|
||||||
|
std::string SimpleNameImpl() const override;
|
||||||
|
|
||||||
static std::string ComputeName(const std::string& basename,
|
static std::string ComputeName(const std::string& basename,
|
||||||
MaybeSpecializationKey specialized_from);
|
MaybeSpecializationKey specialized_from);
|
||||||
|
|
||||||
const StructDeclaration* decl_;
|
const StructDeclaration* decl_;
|
||||||
|
std::string generated_type_name_;
|
||||||
MaybeSpecializationKey specialized_from_;
|
MaybeSpecializationKey specialized_from_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user