SymbolObfus支持 `[ObfuzIgnore]`

backup
walon 2025-05-13 11:46:44 +08:00
parent abecc20a4a
commit 09e4f3269c
1 changed files with 37 additions and 1 deletions

View File

@ -1,4 +1,5 @@
using dnlib.DotNet; using dnlib.DotNet;
using Obfuz.Utils;
namespace Obfuz.ObfusPasses.SymbolObfus.Policies namespace Obfuz.ObfusPasses.SymbolObfus.Policies
{ {
@ -11,21 +12,56 @@ namespace Obfuz.ObfusPasses.SymbolObfus.Policies
{ {
return false; return false;
} }
if (MetaUtil.HasObfuzIgnoreAttribute(typeDef))
{
return false;
}
return true; return true;
} }
public override bool NeedRename(MethodDef methodDef) public override bool NeedRename(MethodDef methodDef)
{ {
return methodDef.Name != ".ctor" && methodDef.Name != ".cctor"; if (methodDef.Name == ".ctor" || methodDef.Name == ".cctor")
{
return false;
}
if (MetaUtil.HasObfuzIgnoreAttribute(methodDef) || MetaUtil.HasObfuzIgnoreAttribute(methodDef.DeclaringType))
{
return false;
}
return true;
} }
public override bool NeedRename(FieldDef fieldDef) public override bool NeedRename(FieldDef fieldDef)
{ {
if (MetaUtil.HasObfuzIgnoreAttribute(fieldDef) || MetaUtil.HasObfuzIgnoreAttribute(fieldDef.DeclaringType))
{
return false;
}
if (fieldDef.DeclaringType.IsEnum && fieldDef.Name == "value__") if (fieldDef.DeclaringType.IsEnum && fieldDef.Name == "value__")
{ {
return false; return false;
} }
return true; return true;
} }
public override bool NeedRename(PropertyDef propertyDef)
{
if (MetaUtil.HasObfuzIgnoreAttribute(propertyDef) || MetaUtil.HasObfuzIgnoreAttribute(propertyDef.DeclaringType))
{
return false;
}
return true;
}
public override bool NeedRename(EventDef eventDef)
{
if (MetaUtil.HasObfuzIgnoreAttribute(eventDef) || MetaUtil.HasObfuzIgnoreAttribute(eventDef.DeclaringType))
{
return false;
}
return true;
}
} }
} }