示例#1
0
        internal static CommentHelpInfo GetHelpContents(List <System.Management.Automation.Language.Token> comments, List <string> parameterDescriptions)
        {
            HelpCommentsParser parser = new HelpCommentsParser(parameterDescriptions);

            parser.AnalyzeCommentBlock(comments);
            return(parser._sections);
        }
示例#2
0
        internal static bool IsCommentHelpText(List <System.Management.Automation.Language.Token> commentBlock)
        {
            if ((commentBlock == null) || (commentBlock.Count == 0))
            {
                return(false);
            }
            HelpCommentsParser parser = new HelpCommentsParser();

            return(parser.AnalyzeCommentBlock(commentBlock));
        }
示例#3
0
        internal static HelpInfo CreateFromComments(
            ExecutionContext context,
            CommandInfo commandInfo,
            List <Token> comments,
            List <List <Token> > parameterComments,
            out string helpFile)
        {
            HelpCommentsParser helpCommentsParser = new HelpCommentsParser(commandInfo, parameterComments);

            helpCommentsParser.AnalyzeCommentBlock(comments);
            helpFile = helpCommentsParser.GetHelpFile(commandInfo);
            RemoteHelpInfo remoteHelpInfo = helpCommentsParser.GetRemoteHelpInfo(context, commandInfo);

            if (remoteHelpInfo != null)
            {
                return((HelpInfo)remoteHelpInfo);
            }
            MamlCommandHelpInfo helpInfo = MamlCommandHelpInfo.Load((XmlNode)helpCommentsParser.BuildXmlFromComments().DocumentElement, commandInfo.HelpCategory);

            if (helpInfo != null)
            {
                helpCommentsParser.SetAdditionalData(helpInfo);
                if (!string.IsNullOrEmpty(helpCommentsParser.sections.forwardHelpTargetName) || !string.IsNullOrEmpty(helpCommentsParser.sections.fowardHelpCategory))
                {
                    if (string.IsNullOrEmpty(helpCommentsParser.sections.forwardHelpTargetName))
                    {
                        helpInfo.ForwardTarget = helpInfo.Name;
                    }
                    else
                    {
                        helpInfo.ForwardTarget = helpCommentsParser.sections.forwardHelpTargetName;
                    }
                    if (!string.IsNullOrEmpty(helpCommentsParser.sections.fowardHelpCategory))
                    {
                        try
                        {
                            helpInfo.ForwardHelpCategory = (HelpCategory)Enum.Parse(typeof(HelpCategory), helpCommentsParser.sections.fowardHelpCategory, true);
                        }
                        catch (ArgumentException ex)
                        {
                        }
                    }
                    else
                    {
                        helpInfo.ForwardHelpCategory = HelpCategory.Alias | HelpCategory.Cmdlet | HelpCategory.ScriptCommand | HelpCategory.Function | HelpCategory.Filter | HelpCategory.ExternalScript;
                    }
                }
            }
            return((HelpInfo)helpInfo);
        }
示例#4
0
        internal static HelpInfo CreateFromComments(ExecutionContext context, CommandInfo commandInfo, List <System.Management.Automation.Language.Token> comments, List <string> parameterDescriptions, bool dontSearchOnRemoteComputer, out string helpFile, out string helpUriFromDotLink)
        {
            HelpCommentsParser helpCommentsParser = new HelpCommentsParser(commandInfo, parameterDescriptions);

            helpCommentsParser.AnalyzeCommentBlock(comments);
            if ((helpCommentsParser._sections.Links != null) && (helpCommentsParser._sections.Links.Count != 0))
            {
                helpUriFromDotLink = helpCommentsParser._sections.Links[0];
            }
            else
            {
                helpUriFromDotLink = null;
            }
            helpFile = helpCommentsParser.GetHelpFile(commandInfo);
            if (((comments.Count == 1) && helpCommentsParser.isExternalHelpSet) && (helpFile == null))
            {
                return(null);
            }
            return(CreateFromComments(context, commandInfo, helpCommentsParser, dontSearchOnRemoteComputer));
        }
示例#5
0
        /// <summary>
        /// Analyze a block of comments to determine if it is a special help block.
        /// </summary>
        /// <param name="commentBlock">The block of comments to analyze.</param>
        /// <returns>true if the block is our special comment block for help, false otherwise.</returns>
        internal static bool IsCommentHelpText(List<Token> commentBlock)
        {
            if ((commentBlock == null) || (commentBlock.Count == 0))
                return false;

            HelpCommentsParser generator = new HelpCommentsParser();
            return generator.AnalyzeCommentBlock(commentBlock);
        }
示例#6
0
        internal static HelpInfo CreateFromComments(ExecutionContext context,
                                                    CommandInfo commandInfo,
                                                    List<Language.Token> comments,
                                                    List<string> parameterDescriptions,
                                                    bool dontSearchOnRemoteComputer,
                                                    out string helpFile, out string helpUriFromDotLink)
        {
            HelpCommentsParser helpCommentsParser = new HelpCommentsParser(commandInfo, parameterDescriptions);
            helpCommentsParser.AnalyzeCommentBlock(comments);

            if (helpCommentsParser._sections.Links != null && helpCommentsParser._sections.Links.Count != 0)
            {
                helpUriFromDotLink = helpCommentsParser._sections.Links[0];
            }
            else
            {
                helpUriFromDotLink = null;
            }

            helpFile = helpCommentsParser.GetHelpFile(commandInfo);

            // If only .ExternalHelp is defined and the help file is not found, then we
            // use the metadata driven help
            if (comments.Count == 1 && helpCommentsParser.isExternalHelpSet && helpFile == null)
            {
                return null;
            }

            return CreateFromComments(context, commandInfo, helpCommentsParser, dontSearchOnRemoteComputer);
        }
示例#7
0
 internal static CommentHelpInfo GetHelpContents(List<Language.Token> comments, List<string> parameterDescriptions)
 {
     HelpCommentsParser helpCommentsParser = new HelpCommentsParser(parameterDescriptions);
     helpCommentsParser.AnalyzeCommentBlock(comments);
     return helpCommentsParser._sections;
 }
示例#8
0
 internal static bool IsCommentHelpText(List<System.Management.Automation.Language.Token> commentBlock)
 {
     if ((commentBlock == null) || (commentBlock.Count == 0))
     {
         return false;
     }
     HelpCommentsParser parser = new HelpCommentsParser();
     return parser.AnalyzeCommentBlock(commentBlock);
 }
示例#9
0
 internal static CommentHelpInfo GetHelpContents(List<System.Management.Automation.Language.Token> comments, List<string> parameterDescriptions)
 {
     HelpCommentsParser parser = new HelpCommentsParser(parameterDescriptions);
     parser.AnalyzeCommentBlock(comments);
     return parser._sections;
 }
示例#10
0
 internal static HelpInfo CreateFromComments(ExecutionContext context, CommandInfo commandInfo, List<System.Management.Automation.Language.Token> comments, List<string> parameterDescriptions, bool dontSearchOnRemoteComputer, out string helpFile, out string helpUriFromDotLink)
 {
     HelpCommentsParser helpCommentsParser = new HelpCommentsParser(commandInfo, parameterDescriptions);
     helpCommentsParser.AnalyzeCommentBlock(comments);
     if ((helpCommentsParser._sections.Links != null) && (helpCommentsParser._sections.Links.Count != 0))
     {
         helpUriFromDotLink = helpCommentsParser._sections.Links[0];
     }
     else
     {
         helpUriFromDotLink = null;
     }
     helpFile = helpCommentsParser.GetHelpFile(commandInfo);
     if (((comments.Count == 1) && helpCommentsParser.isExternalHelpSet) && (helpFile == null))
     {
         return null;
     }
     return CreateFromComments(context, commandInfo, helpCommentsParser, dontSearchOnRemoteComputer);
 }