mirror of
https://github.com/beefytech/Beef.git
synced 2025-06-10 04:22:20 +02:00
Made open emit markers even more persistent
This commit is contained in:
parent
5763ac7d83
commit
e3b3089623
4 changed files with 36 additions and 10 deletions
|
@ -5858,10 +5858,13 @@ namespace IDE.ui
|
|||
{
|
||||
if (entry.mParseRevision != data.mCollapseParseRevision)
|
||||
{
|
||||
if (mEmbeds.GetAndRemove(entry.mAnchorLine) case .Ok(let val))
|
||||
if (mEmbeds.TryGet(entry.mAnchorLine, ?, var value))
|
||||
{
|
||||
//Debug.WriteLine($" Deleting(2) {val.value}");
|
||||
delete val.value;
|
||||
if (!(value is EmitEmbed))
|
||||
{
|
||||
mEmbeds.Remove(entry.mAnchorLine);
|
||||
delete value;
|
||||
}
|
||||
}
|
||||
@entry.Remove();
|
||||
}
|
||||
|
@ -6275,8 +6278,15 @@ namespace IDE.ui
|
|||
|
||||
if (failed)
|
||||
{
|
||||
if (mEmbeds.GetAndRemove(prevAnchorLine) case .Ok(let val))
|
||||
delete val.value;
|
||||
if (mEmbeds.TryGet(prevAnchorLine, ?, var value))
|
||||
{
|
||||
if (!(value is EmitEmbed))
|
||||
{
|
||||
mEmbeds.Remove(prevAnchorLine);
|
||||
delete value;
|
||||
}
|
||||
}
|
||||
|
||||
entry.mDeleted = true;
|
||||
}
|
||||
|
||||
|
|
|
@ -4858,9 +4858,8 @@ void BfModule::DoPopulateType(BfType* resolvedTypeRef, BfPopulateType populateTy
|
|||
typeInstance->mCeTypeInfo->mHash = Val128();
|
||||
}
|
||||
|
||||
if ((typeInstance->mCeTypeInfo->mFailed) &&
|
||||
(prevHadEmissions) &&
|
||||
(typeInstance->mCeTypeInfo->mEmitSourceMap.IsEmpty()))
|
||||
if (((typeInstance->mCeTypeInfo->mFailed) || (typeInstance->mTypeDef->HasParsingFailed())) &&
|
||||
(prevHadEmissions))
|
||||
{
|
||||
// Just add a marker to retain the previous open emits
|
||||
typeInstance->mCeTypeInfo->mEmitSourceMap[-1] = BfCeTypeEmitSource();
|
||||
|
|
|
@ -1030,6 +1030,22 @@ bool BfTypeDef::HasCustomAttributes()
|
|||
return false;
|
||||
}
|
||||
|
||||
bool BfTypeDef::HasParsingFailed()
|
||||
{
|
||||
auto parser = mTypeDeclaration->GetParser();
|
||||
if ((parser != NULL) && (parser->mParsingFailed))
|
||||
return true;
|
||||
|
||||
for (auto partial : mPartials)
|
||||
{
|
||||
parser = partial->mTypeDeclaration->GetParser();
|
||||
if ((parser != NULL) && (parser->mParsingFailed))
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
//////////////////////////////////////////////////////////////////////////
|
||||
|
||||
BfProject::BfProject()
|
||||
|
|
|
@ -1219,6 +1219,7 @@ public:
|
|||
BfFieldDef* GetFieldByName(const StringImpl& name);
|
||||
bool HasAutoProperty(BfPropertyDeclaration* propertyDeclaration);
|
||||
bool ContainsPartial(BfTypeDef* partialTypeDef);
|
||||
bool HasParsingFailed();
|
||||
String GetAutoPropertyName(BfPropertyDeclaration* propertyDeclaration);
|
||||
BfAstNode* GetRefNode();
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue