本文整理汇总了C#中Analyzer.EnterMethodDeclaration方法的典型用法代码示例。如果您正苦于以下问题:C# Analyzer.EnterMethodDeclaration方法的具体用法?C# Analyzer.EnterMethodDeclaration怎么用?C# Analyzer.EnterMethodDeclaration使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Analyzer
的用法示例。
在下文中一共展示了Analyzer.EnterMethodDeclaration方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Analyze
internal override void Analyze(Analyzer/*!*/ analyzer)
{
// method redeclared:
if (method == null) return;
base.Analyze(analyzer);
PhpType declaring_type = analyzer.CurrentType;
analyzer.EnterMethodDeclaration(method);
typeSignature.Analyze(analyzer);
signature.Analyze(analyzer);
method.Validate(analyzer.ErrorSink);
// note, if the declaring type's base is unknown then it cannot be a CLR type;
ClrType base_clr_type = method.DeclaringType.Base as ClrType;
if (baseCtorParams != null)
{
if (base_clr_type != null)
{
AnalyzeBaseCtorCallParams(analyzer, base_clr_type);
}
else if (!method.IsConstructor || method.DeclaringType.Base == null || body == null)
{
analyzer.ErrorSink.Add(Errors.UnexpectedParentCtorInvocation, analyzer.SourceUnit, position);
baseCtorParams = null;
}
else if (method.DeclaringType.Base.Constructor == null)
{
// base class has no constructor, the default parameterless is silently called (and that does nothing);
// report error, if there are any parameters passed to the parameterless ctor:
if (baseCtorParams.Count > 0)
analyzer.ErrorSink.Add(Errors.UnexpectedParentCtorInvocation, analyzer.SourceUnit, position);
baseCtorParams = null;
}
else
{
GenericQualifiedName parent_name = new GenericQualifiedName(new QualifiedName(Name.ParentClassName));
DirectStMtdCall call_expr = new DirectStMtdCall(
position, parent_name, Position.Invalid,
method.DeclaringType.Base.Constructor.Name, Position.Invalid,
baseCtorParams, TypeRef.EmptyList);
body.Insert(0, new ExpressionStmt(position, call_expr));
baseCtorParams = null;
}
}
else
{
// the type immediately extends CLR type with no default ctor, yet there is no call to the base ctor;
// note, all constructor overloads reflected from the CLR type are visible as we are in a subclass:
if (method.IsConstructor && base_clr_type != null && !base_clr_type.ClrConstructor.HasParameterlessOverload)
{
analyzer.ErrorSink.Add(Errors.ExpectingParentCtorInvocation, analyzer.SourceUnit, position);
}
}
if(method.IsDllImport && !method.IsStatic)
analyzer.ErrorSink.Add(Errors.DllImportMethodMustBeStatic, analyzer.SourceUnit, position);
if(method.IsDllImport && method.IsAbstract)
analyzer.ErrorSink.Add(Errors.DllImportMethodCannotBeAbstract, analyzer.SourceUnit, position);
if (body != null)
body.Analyze(analyzer);
method.ValidateBody(analyzer.ErrorSink);
analyzer.LeaveMethodDeclaration();
// add entry point if applicable:
analyzer.SetEntryPoint(method, position);
}