1
0
Fork 0
mirror of https://github.com/beefytech/Beef.git synced 2025-06-08 11:38:21 +02:00

File-scoped namespaces

This commit is contained in:
Brian Fiete 2022-04-17 08:40:25 -07:00
parent 2d808ec649
commit f3f2f4c6ec
8 changed files with 76 additions and 18 deletions

View file

@ -2065,7 +2065,7 @@ public:
BfTokenNode* mNamespaceNode;
BfIdentifierNode* mNameNode;
BfBlock* mBlock;
BfAstNode* mBody;
}; BF_AST_DECL(BfNamespaceDeclaration, BfAstNode);
class BfBinaryOperatorExpression : public BfExpression

View file

@ -9548,7 +9548,7 @@ BF_EXPORT const char* BF_CALLTYPE BfCompiler_GetCollapseRegions(BfCompiler* bfCo
virtual void Visit(BfNamespaceDeclaration* namespaceDeclaration) override
{
Add(namespaceDeclaration->mNamespaceNode, namespaceDeclaration->mBlock, 'N');
Add(namespaceDeclaration->mNamespaceNode, namespaceDeclaration->mBody, 'N');
BfElementVisitor::Visit(namespaceDeclaration);
}

View file

@ -68,6 +68,7 @@ BfDefBuilder::BfDefBuilder(BfSystem* bfSystem)
mFullHashCtx = NULL;
mSignatureHashCtx = NULL;
mNamespaceBlockDepth = 0;
}
BfDefBuilder::~BfDefBuilder()
@ -2493,10 +2494,42 @@ void BfDefBuilder::Visit(BfUsingModDirective* usingDirective)
mStaticSearch.Add(usingDirective->mTypeRef);
}
void BfDefBuilder::SetNamespaceState(const NamespaceState& namespaceState)
{
while ((int)mNamespaceSearch.size() > namespaceState.mNamespaceSearchCount)
{
BfAtomComposite& atomComposite = mNamespaceSearch[0];
mSystem->ReleaseAtomComposite(atomComposite);
mNamespaceSearch.RemoveAt(0);
}
mNamespace = namespaceState.mNamespace;
}
void BfDefBuilder::Visit(BfNamespaceDeclaration* namespaceDeclaration)
{
BfAtomComposite prevNamespace = mNamespace;
int prevNamespaceSearchCount = (int)mNamespaceSearch.size();
auto blockNode = BfNodeDynCast<BfBlock>(namespaceDeclaration->mBody);
bool isFileLevel = (blockNode == NULL) && (namespaceDeclaration->mBody != NULL);
if (mNamespaceBlockDepth < mFileLevelNamespaceState.mSize)
{
auto& prevNamespaceState = mFileLevelNamespaceState[mNamespaceBlockDepth];
if (prevNamespaceState.mNamespaceSearchCount != -1)
{
SetNamespaceState(prevNamespaceState);
prevNamespaceState.mNamespaceSearchCount = -1;
}
}
NamespaceState namespaceState;
namespaceState.mNamespace = mNamespace;
namespaceState.mNamespaceSearchCount = (int)mNamespaceSearch.size();
if (isFileLevel)
{
while (mNamespaceBlockDepth >= mFileLevelNamespaceState.mSize)
mFileLevelNamespaceState.Add(NamespaceState());
mFileLevelNamespaceState[mNamespaceBlockDepth] = namespaceState;
}
if (namespaceDeclaration->mNameNode == NULL)
return;
@ -2531,14 +2564,15 @@ void BfDefBuilder::Visit(BfNamespaceDeclaration* namespaceDeclaration)
mSystem->ReleaseAtom(namespaceAtom);
}
VisitChild(namespaceDeclaration->mBlock);
while ((int)mNamespaceSearch.size() > prevNamespaceSearchCount)
if (blockNode != NULL)
{
BfAtomComposite& atomComposite = mNamespaceSearch[0];
mSystem->ReleaseAtomComposite(atomComposite);
mNamespaceSearch.RemoveAt(0);
mNamespaceBlockDepth++;
VisitChild(blockNode);
mNamespaceBlockDepth--;
}
mNamespace = prevNamespace;
if (!isFileLevel)
SetNamespaceState(namespaceState);
}
void BfDefBuilder::Visit(BfBlock* block)

View file

@ -11,6 +11,18 @@ class BfResolvePassData;
class BfDefBuilder : public BfStructuralVisitor
{
public:
struct NamespaceState
{
BfAtomComposite mNamespace;
int mNamespaceSearchCount;
NamespaceState()
{
mNamespaceSearchCount = -1;
}
};
public:
BfSource* mCurSource;
BfSystem* mSystem;
@ -28,6 +40,9 @@ public:
HashContext* mFullHashCtx;
HashContext* mSignatureHashCtx;
Array<NamespaceState> mFileLevelNamespaceState;
int mNamespaceBlockDepth;
public:
void ParseGenericParams(BfGenericParamsDeclaration* genericParamsDecl, BfGenericConstraintsDeclaration* genericConstraints, Array<BfGenericParamDef*>& genericParams, Array<BfExternalConstraintDef>* externConstraintDefs, int outerGenericSize, bool isInGeneric);
BfProtection GetProtection(BfAstNode* protectionNode);
@ -45,6 +60,7 @@ public:
void ParseAttributes(BfAttributeDirective* attributes, BfTypeDef* typeDef);
BfMethodDef* CreateMethodDef(BfMethodDeclaration* methodDecl, BfMethodDef* outerMethodDef = NULL);
BfError* Fail(const StringImpl& errorStr, BfAstNode* refNode);
void SetNamespaceState(const NamespaceState& namespaceState);
public:
BfDefBuilder(BfSystem* bfSystem);

View file

@ -1225,7 +1225,7 @@ void BfElementVisitor::Visit(BfNamespaceDeclaration* namespaceDeclaration)
VisitChild(namespaceDeclaration->mNamespaceNode);
VisitChild(namespaceDeclaration->mNameNode);
VisitChild(namespaceDeclaration->mBlock);
VisitChild(namespaceDeclaration->mBody);
}
void BfElementVisitor::Visit(BfBlock* block)

View file

@ -76,7 +76,7 @@ void BfNamespaceVisitor::Visit(BfNamespaceDeclaration* namespaceDeclaration)
if (mResolvePassData->mAutoComplete != NULL)
mResolvePassData->mAutoComplete->CheckNamespace(namespaceDeclaration->mNameNode, mNamespace);
mResolvePassData->HandleNamespaceReference(namespaceDeclaration->mNameNode, mNamespace);
VisitChild(namespaceDeclaration->mBlock);
VisitChild(namespaceDeclaration->mBody);
mNamespace = prevNamespace;
}

View file

@ -3008,7 +3008,7 @@ void BfPrinter::Visit(BfNamespaceDeclaration* namespaceDeclaration)
VisitChild(namespaceDeclaration->mNamespaceNode);
ExpectSpace();
VisitChild(namespaceDeclaration->mNameNode);
VisitChild(namespaceDeclaration->mBlock);
VisitChild(namespaceDeclaration->mBody);
}
void BfPrinter::DoBlockOpen(BfAstNode* prevNode, BfTokenNode* blockOpen, BfTokenNode* blockClose, bool queue, BlockState& blockState)

View file

@ -8537,14 +8537,22 @@ BfAstNode* BfReducer::CreateTopLevelObject(BfTokenNode* tokenNode, BfAttributeDi
ReplaceNode(tokenNode, namespaceDeclaration);
MoveNode(identifierNode, namespaceDeclaration);
auto blockNode = ExpectBlockAfter(namespaceDeclaration);
if (blockNode == NULL)
BfAstNode* bodyNode = NULL;
BfBlock* blockNode = NULL;
if (auto nextToken = BfNodeDynCast<BfTokenNode>(mVisitorPos.GetNext()))
bodyNode = ExpectTokenAfter(namespaceDeclaration, BfToken_Semicolon);
else
bodyNode = blockNode = ExpectBlockAfter(namespaceDeclaration);
if (bodyNode == NULL)
return namespaceDeclaration;
MoveNode(blockNode, namespaceDeclaration);
namespaceDeclaration->mBlock = blockNode;
MoveNode(bodyNode, namespaceDeclaration);
namespaceDeclaration->mBody = bodyNode;
mCurNamespaceStack.Add(namespaceDeclaration);
HandleTopLevel(namespaceDeclaration->mBlock);
if (blockNode != NULL)
HandleTopLevel(blockNode);
mCurNamespaceStack.pop_back();
return namespaceDeclaration;
}