當前位置: 首頁>>代碼示例>>C#>>正文


C# Analyzer.IsInsideIncompleteClass方法代碼示例

本文整理匯總了C#中Analyzer.IsInsideIncompleteClass方法的典型用法代碼示例。如果您正苦於以下問題:C# Analyzer.IsInsideIncompleteClass方法的具體用法?C# Analyzer.IsInsideIncompleteClass怎麽用?C# Analyzer.IsInsideIncompleteClass使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Analyzer的用法示例。


在下文中一共展示了Analyzer.IsInsideIncompleteClass方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Analyze

		/// <include file='Doc/Nodes.xml' path='doc/method[@name="Statement.Analyze"]/*'/>
		internal override Statement/*!*/ Analyze(Analyzer/*!*/ analyzer)
		{
			// functions in incomplete (not emitted) class can't be emitted
			function.Declaration.IsInsideIncompleteClass = analyzer.IsInsideIncompleteClass();

			attributes.Analyze(analyzer, this);
			
			// function is analyzed even if it is unreachable in order to discover more errors at compile-time:
			function.Declaration.IsUnreachable = analyzer.IsThisCodeUnreachable();

			if (function.Declaration.IsUnreachable)
				analyzer.ReportUnreachableCode(position);

			analyzer.EnterFunctionDeclaration(function);

			typeSignature.Analyze(analyzer);
			signature.Analyze(analyzer);

			function.Validate(analyzer.ErrorSink);

            this.Body.Analyze(analyzer);
			
			// validate function and its body:
			function.ValidateBody(analyzer.ErrorSink);

			/*
			if (docComment != null)
				AnalyzeDocComment(analyzer);
			*/
			
			analyzer.LeaveFunctionDeclaration();

			if (function.Declaration.IsUnreachable)
			{
				return EmptyStmt.Unreachable;
			}
			else
			{
				// add entry point if applicable:
				analyzer.SetEntryPoint(function, position);
				return this;
			}
		}
開發者ID:hansdude,項目名稱:Phalanger,代碼行數:44,代碼來源:FunctionDecl.cs

示例2: Analyze

		/// <include file='Doc/Nodes.xml' path='doc/method[@name="Statement.Analyze"]/*'/>
		internal override Statement Analyze(Analyzer/*!*/ analyzer)
		{
			// remove classes that has been merged to the aggregate from the further processing:
			if (IsPartialMergeResiduum)
				return EmptyStmt.PartialMergeResiduum;

			// functions in incomplete (not emitted) class can't be emitted
			type.Declaration.IsInsideIncompleteClass = analyzer.IsInsideIncompleteClass();

			// the ClassDecl is fully analyzed even if it will be replaced in the AST by EvalEx
			// and even if it is unreachable in order to discover all possible errors in compile-time

			type.Declaration.IsUnreachable = analyzer.IsThisCodeUnreachable();

			if (type.Declaration.IsUnreachable)
				analyzer.ReportUnreachableCode(position);

			attributes.Analyze(analyzer, this);
			typeSignature.Analyze(analyzer);

			analyzer.EnterTypeDecl(type);

            foreach (var member in members)
            {
                member.EnterAnalyzer(analyzer);
                member.Analyze(analyzer);
                member.LeaveAnalyzer(analyzer);
            }

			analyzer.LeaveTypeDecl();

			AnalyzeDocComments(analyzer);

			// validate the type after all members has been analyzed and validated:
			type.Validate(analyzer.ErrorSink);

			if (type.Declaration.IsUnreachable)
			{
				// only a conditional declaration can be unreachable
				// => not emiting the declaration is ok

				return EmptyStmt.Unreachable;
			}
			else if (!type.IsComplete)
			{
				// mark all functions declared in incomplete class as 'non-compilable'

				// convert incomplete class to an eval if applicable:
				if (analyzer.SourceUnit.CompilationUnit.IsPure && analyzer.CurrentType == null &&
					analyzer.CurrentRoutine == null)
				{
					// error, since there is no place for global code in pure mode:
					analyzer.ErrorSink.Add(Errors.IncompleteClass, analyzer.SourceUnit, position, this.name);
					return this;
				}

				if (analyzer.SourceUnit.CompilationUnit.IsTransient)
				{
					TransientCompilationUnit transient_unit = (TransientCompilationUnit)analyzer.SourceUnit.CompilationUnit;

					// report an error only for synthetic evals as we are 100% sure that the class cannot be completed;
					// note that a synthetic eval can be created even in transient code as some base types could be 
					// declared there conditionally:
					if (transient_unit.EvalKind == EvalKinds.SyntheticEval)
					{
						analyzer.ErrorSink.Add(Errors.IncompleteClass, analyzer.SourceUnit, position, this.name);
						return this;
					}
				}

                // report the warning, incomplete_class
                analyzer.ErrorSink.Add(Warnings.IncompleteClass, analyzer.SourceUnit, position, this.name);

                this.typeDefinitionCode = analyzer.SourceUnit.GetSourceCode(entireDeclarationPosition);
                //// we return an eval
                //EvalEx evalEx = new EvalEx(
                //    entireDeclarationPosition, this.typeDefinitionCode,
                //    (this.Namespace != null && this.Namespace.QualifiedName.Namespaces.Length > 0) ? this.Namespace.QualifiedName : (QualifiedName?)null,
                //    this.validAliases);
                //Statement stmt = new ExpressionStmt(entireDeclarationPosition, evalEx);

                //// this annotation is for the duck-type generation - we need to know the original typedecl
                //evalEx.Annotations.Set<TypeDecl>(this);

                //return stmt;

                // we emit eval
                return this;
			}
			else
			{
				return this;
			}
		}
開發者ID:Ashod,項目名稱:Phalanger,代碼行數:95,代碼來源:TypeDecl.cs


注:本文中的Analyzer.IsInsideIncompleteClass方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。