mirror of
https://github.com/MaskRay/ccls.git
synced 2025-02-20 07:30:50 +00:00
Support unions and enums
This commit is contained in:
parent
6b95f51a25
commit
5f0f290d18
30
main.cpp
30
main.cpp
@ -802,6 +802,8 @@ bool IsTypeDefinition(const CXIdxContainerInfo* container) {
|
||||
return false;
|
||||
|
||||
switch (container->cursor.kind) {
|
||||
case CXCursor_EnumDecl:
|
||||
case CXCursor_UnionDecl:
|
||||
case CXCursor_StructDecl:
|
||||
case CXCursor_ClassDecl:
|
||||
return true;
|
||||
@ -936,6 +938,7 @@ void indexDeclaration(CXClientData client_data, const CXIdxDeclInfo* decl) {
|
||||
break;
|
||||
}
|
||||
|
||||
case CXIdxEntity_EnumConstant:
|
||||
case CXIdxEntity_Field:
|
||||
case CXIdxEntity_Variable:
|
||||
case CXIdxEntity_CXXStaticVariable:
|
||||
@ -1115,6 +1118,8 @@ void indexDeclaration(CXClientData client_data, const CXIdxDeclInfo* decl) {
|
||||
break;
|
||||
}
|
||||
|
||||
case CXIdxEntity_Enum:
|
||||
case CXIdxEntity_Union:
|
||||
case CXIdxEntity_Struct:
|
||||
case CXIdxEntity_CXXClass:
|
||||
{
|
||||
@ -1143,15 +1148,17 @@ void indexDeclaration(CXClientData client_data, const CXIdxDeclInfo* decl) {
|
||||
|
||||
// Add type-level inheritance information.
|
||||
CXIdxCXXClassDeclInfo const* class_info = clang_index_getCXXClassDeclInfo(decl);
|
||||
for (unsigned int i = 0; i < class_info->numBases; ++i) {
|
||||
const CXIdxBaseClassInfo* base_class = class_info->bases[i];
|
||||
if (class_info) {
|
||||
for (unsigned int i = 0; i < class_info->numBases; ++i) {
|
||||
const CXIdxBaseClassInfo* base_class = class_info->bases[i];
|
||||
|
||||
std::optional<TypeId> parent_type_id = ResolveDeclToType(db, base_class->cursor, true /*is_interesting*/, decl->semanticContainer, decl->lexicalContainer);
|
||||
TypeDef* type_def = db->Resolve(type_id); // type_def ptr could be invalidated by ResolveDeclToType.
|
||||
if (parent_type_id) {
|
||||
TypeDef* parent_type_def = db->Resolve(parent_type_id.value());
|
||||
parent_type_def->derived.push_back(type_id);
|
||||
type_def->parents.push_back(parent_type_id.value());
|
||||
std::optional<TypeId> parent_type_id = ResolveDeclToType(db, base_class->cursor, true /*is_interesting*/, decl->semanticContainer, decl->lexicalContainer);
|
||||
TypeDef* type_def = db->Resolve(type_id); // type_def ptr could be invalidated by ResolveDeclToType.
|
||||
if (parent_type_id) {
|
||||
TypeDef* parent_type_def = db->Resolve(parent_type_id.value());
|
||||
parent_type_def->derived.push_back(type_id);
|
||||
type_def->parents.push_back(parent_type_id.value());
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
@ -1186,9 +1193,8 @@ void indexEntityReference(CXClientData client_data, const CXIdxEntityRefInfo* re
|
||||
ParsingDatabase* db = param->db;
|
||||
clang::Cursor cursor(ref->cursor);
|
||||
|
||||
// TODO: Index entity call/ctor creation, like Foo().x = 3
|
||||
|
||||
switch (ref->referencedEntity->kind) {
|
||||
case CXIdxEntity_EnumConstant:
|
||||
case CXIdxEntity_CXXStaticVariable:
|
||||
case CXIdxEntity_Variable:
|
||||
case CXIdxEntity_Field:
|
||||
@ -1255,6 +1261,8 @@ void indexEntityReference(CXClientData client_data, const CXIdxEntityRefInfo* re
|
||||
|
||||
case CXIdxEntity_Typedef:
|
||||
case CXIdxEntity_CXXTypeAlias:
|
||||
case CXIdxEntity_Enum:
|
||||
case CXIdxEntity_Union:
|
||||
case CXIdxEntity_Struct:
|
||||
case CXIdxEntity_CXXClass:
|
||||
{
|
||||
@ -1431,7 +1439,7 @@ int main(int argc, char** argv) {
|
||||
|
||||
for (std::string path : GetFilesInFolder("tests")) {
|
||||
//if (path != "tests/declaration_vs_definition/class_member_static.cc") continue;
|
||||
//if (path != "tests/usage/type_usage_typedef_and_using_template.cc") continue;
|
||||
//if (path != "tests/enums/enum_class_decl.cc") continue;
|
||||
//if (path != "tests/constructors/constructor.cc") continue;
|
||||
//if (path == "tests/constructors/destructor.cc") continue;
|
||||
//if (path == "tests/usage/func_usage_call_method.cc") continue;
|
||||
|
37
tests/enums/enum_class_decl.cc
Normal file
37
tests/enums/enum_class_decl.cc
Normal file
@ -0,0 +1,37 @@
|
||||
enum class Foo {
|
||||
A,
|
||||
B = 20
|
||||
};
|
||||
|
||||
/*
|
||||
OUTPUT:
|
||||
{
|
||||
"types": [{
|
||||
"id": 0,
|
||||
"usr": "c:@E@Foo",
|
||||
"short_name": "Foo",
|
||||
"qualified_name": "Foo",
|
||||
"definition": "1:1:12",
|
||||
"vars": [0, 1],
|
||||
"all_uses": ["1:1:12"]
|
||||
}],
|
||||
"functions": [],
|
||||
"variables": [{
|
||||
"id": 0,
|
||||
"usr": "c:@E@Foo@A",
|
||||
"short_name": "A",
|
||||
"qualified_name": "Foo::A",
|
||||
"definition": "1:2:3",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:2:3"]
|
||||
}, {
|
||||
"id": 1,
|
||||
"usr": "c:@E@Foo@B",
|
||||
"short_name": "B",
|
||||
"qualified_name": "Foo::B",
|
||||
"definition": "1:3:3",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:3:3"]
|
||||
}]
|
||||
}
|
||||
*/
|
37
tests/enums/enum_decl.cc
Normal file
37
tests/enums/enum_decl.cc
Normal file
@ -0,0 +1,37 @@
|
||||
enum Foo {
|
||||
A,
|
||||
B = 20
|
||||
};
|
||||
|
||||
/*
|
||||
OUTPUT:
|
||||
{
|
||||
"types": [{
|
||||
"id": 0,
|
||||
"usr": "c:@E@Foo",
|
||||
"short_name": "Foo",
|
||||
"qualified_name": "Foo",
|
||||
"definition": "1:1:6",
|
||||
"vars": [0, 1],
|
||||
"all_uses": ["1:1:6"]
|
||||
}],
|
||||
"functions": [],
|
||||
"variables": [{
|
||||
"id": 0,
|
||||
"usr": "c:@E@Foo@A",
|
||||
"short_name": "A",
|
||||
"qualified_name": "Foo::A",
|
||||
"definition": "1:2:3",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:2:3"]
|
||||
}, {
|
||||
"id": 1,
|
||||
"usr": "c:@E@Foo@B",
|
||||
"short_name": "B",
|
||||
"qualified_name": "Foo::B",
|
||||
"definition": "1:3:3",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:3:3"]
|
||||
}]
|
||||
}
|
||||
*/
|
37
tests/enums/enum_inherit.cc
Normal file
37
tests/enums/enum_inherit.cc
Normal file
@ -0,0 +1,37 @@
|
||||
enum Foo : int {
|
||||
A,
|
||||
B = 20
|
||||
};
|
||||
|
||||
/*
|
||||
OUTPUT:
|
||||
{
|
||||
"types": [{
|
||||
"id": 0,
|
||||
"usr": "c:@E@Foo",
|
||||
"short_name": "Foo",
|
||||
"qualified_name": "Foo",
|
||||
"definition": "1:1:6",
|
||||
"vars": [0, 1],
|
||||
"all_uses": ["1:1:6"]
|
||||
}],
|
||||
"functions": [],
|
||||
"variables": [{
|
||||
"id": 0,
|
||||
"usr": "c:@E@Foo@A",
|
||||
"short_name": "A",
|
||||
"qualified_name": "Foo::A",
|
||||
"definition": "1:2:3",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:2:3"]
|
||||
}, {
|
||||
"id": 1,
|
||||
"usr": "c:@E@Foo@B",
|
||||
"short_name": "B",
|
||||
"qualified_name": "Foo::B",
|
||||
"definition": "1:3:3",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:3:3"]
|
||||
}]
|
||||
}
|
||||
*/
|
47
tests/enums/enum_usage.cc
Normal file
47
tests/enums/enum_usage.cc
Normal file
@ -0,0 +1,47 @@
|
||||
enum class Foo {
|
||||
A,
|
||||
B = 20
|
||||
};
|
||||
|
||||
Foo x = Foo::A;
|
||||
|
||||
/*
|
||||
OUTPUT:
|
||||
{
|
||||
"types": [{
|
||||
"id": 0,
|
||||
"usr": "c:@E@Foo",
|
||||
"short_name": "Foo",
|
||||
"qualified_name": "Foo",
|
||||
"definition": "1:1:12",
|
||||
"vars": [0, 1],
|
||||
"all_uses": ["1:1:12", "*1:6:1", "1:6:9"]
|
||||
}],
|
||||
"functions": [],
|
||||
"variables": [{
|
||||
"id": 0,
|
||||
"usr": "c:@E@Foo@A",
|
||||
"short_name": "A",
|
||||
"qualified_name": "Foo::A",
|
||||
"definition": "1:2:3",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:2:3", "1:6:14"]
|
||||
}, {
|
||||
"id": 1,
|
||||
"usr": "c:@E@Foo@B",
|
||||
"short_name": "B",
|
||||
"qualified_name": "Foo::B",
|
||||
"definition": "1:3:3",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:3:3"]
|
||||
}, {
|
||||
"id": 2,
|
||||
"usr": "c:@x",
|
||||
"short_name": "x",
|
||||
"qualified_name": "x",
|
||||
"definition": "1:6:5",
|
||||
"variable_type": 0,
|
||||
"all_uses": ["1:6:5"]
|
||||
}]
|
||||
}
|
||||
*/
|
37
tests/unions/union_decl.cc
Normal file
37
tests/unions/union_decl.cc
Normal file
@ -0,0 +1,37 @@
|
||||
union Foo {
|
||||
int a;
|
||||
bool b;
|
||||
};
|
||||
|
||||
/*
|
||||
OUTPUT:
|
||||
{
|
||||
"types": [{
|
||||
"id": 0,
|
||||
"usr": "c:@U@Foo",
|
||||
"short_name": "Foo",
|
||||
"qualified_name": "Foo",
|
||||
"definition": "1:1:7",
|
||||
"vars": [0, 1],
|
||||
"all_uses": ["1:1:7"]
|
||||
}],
|
||||
"functions": [],
|
||||
"variables": [{
|
||||
"id": 0,
|
||||
"usr": "c:@U@Foo@FI@a",
|
||||
"short_name": "a",
|
||||
"qualified_name": "Foo::a",
|
||||
"definition": "1:2:7",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:2:7"]
|
||||
}, {
|
||||
"id": 1,
|
||||
"usr": "c:@U@Foo@FI@b",
|
||||
"short_name": "b",
|
||||
"qualified_name": "Foo::b",
|
||||
"definition": "1:3:8",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:3:8"]
|
||||
}]
|
||||
}
|
||||
*/
|
58
tests/unions/union_usage.cc
Normal file
58
tests/unions/union_usage.cc
Normal file
@ -0,0 +1,58 @@
|
||||
union Foo {
|
||||
int a : 5;
|
||||
bool b : 3;
|
||||
};
|
||||
|
||||
Foo f;
|
||||
|
||||
void act(Foo*) {
|
||||
f.a = 3;
|
||||
}
|
||||
|
||||
/*
|
||||
OUTPUT:
|
||||
{
|
||||
"types": [{
|
||||
"id": 0,
|
||||
"usr": "c:@U@Foo",
|
||||
"short_name": "Foo",
|
||||
"qualified_name": "Foo",
|
||||
"definition": "1:1:7",
|
||||
"vars": [0, 1],
|
||||
"all_uses": ["1:1:7", "*1:6:1", "*1:8:10"]
|
||||
}],
|
||||
"functions": [{
|
||||
"id": 0,
|
||||
"usr": "c:@F@act#*$@U@Foo#",
|
||||
"short_name": "act",
|
||||
"qualified_name": "act",
|
||||
"definition": "1:8:6",
|
||||
"all_uses": ["1:8:6"]
|
||||
}],
|
||||
"variables": [{
|
||||
"id": 0,
|
||||
"usr": "c:@U@Foo@FI@a",
|
||||
"short_name": "a",
|
||||
"qualified_name": "Foo::a",
|
||||
"definition": "1:2:7",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:2:7", "1:9:5"]
|
||||
}, {
|
||||
"id": 1,
|
||||
"usr": "c:@U@Foo@FI@b",
|
||||
"short_name": "b",
|
||||
"qualified_name": "Foo::b",
|
||||
"definition": "1:3:8",
|
||||
"declaring_type": 0,
|
||||
"all_uses": ["1:3:8"]
|
||||
}, {
|
||||
"id": 2,
|
||||
"usr": "c:@f",
|
||||
"short_name": "f",
|
||||
"qualified_name": "f",
|
||||
"definition": "1:6:5",
|
||||
"variable_type": 0,
|
||||
"all_uses": ["1:6:5", "1:9:3"]
|
||||
}]
|
||||
}
|
||||
*/
|
Loading…
Reference in New Issue
Block a user