All Downloads are FREE. Search and download functionalities are using the official Maven repository.

progress.Consultingwerk.Studio.SmartDox.ParameterCommentValidator.cls Maven / Gradle / Ivy

There is a newer version: 229
Show newest version
/**********************************************************************
 * Copyright 2013 Consultingwerk Ltd.                                 *
 *                                                                    *
 * Licensed under the Apache License, Version 2.0 (the "License");    *
 * you may not use this file except in compliance with the License.   *
 * You may obtain a copy of the License at                            *
 *                                                                    *
 *     http://www.apache.org/licenses/LICENSE-2.0                     *
 *                                                                    *
 * Unless required by applicable law or agreed to in writing,         *
 * software distributed under the License is distributed on an        * 
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,       *
 * either express or implied. See the License for the specific        *
 * language governing permissions and limitations under the License.  *
 *                                                                    *
 **********************************************************************/
/*------------------------------------------------------------------------
    File        : ParameterCommentValidator
    Purpose     : Validates missing parameter comments in class files
    Syntax      : 
    Description : 
    Author(s)   : Sebastian D?ngel / Consultingwerk Ltd. 
    Created     : Wed Feb 06 09:18:55 CET 2013
    Notes       : 
  ----------------------------------------------------------------------*/

ROUTINE-LEVEL ON ERROR UNDO, THROW.

USING Consultingwerk.Studio.ClassDocumentation.* FROM PROPATH .
USING Consultingwerk.Studio.SmartDox.*           FROM PROPATH .
USING Consultingwerk.Util.*                      FROM PROPATH . 
USING Progress.Lang.*                            FROM PROPATH .

CLASS Consultingwerk.Studio.SmartDox.ParameterCommentValidator: 
    
    { Consultingwerk/Studio/SmartDox/ttMissingParameter.i }
    { Consultingwerk/Studio/ClassDocumentation/dsClassDocumentation.i }
    { Consultingwerk/Studio/ClassDocumentation/eParameterComment.i}
    { Consultingwerk/Util/TempTables/ttFileNames.i }
    
    DEFINE VARIABLE oParser AS ClassDocumentationParser NO-UNDO . 
    
    /*------------------------------------------------------------------------------
        Purpose: Gets and sets if verbose messages should be generated 
        Notes:   
    ------------------------------------------------------------------------------*/
    DEFINE PUBLIC PROPERTY Verbose AS LOGICAL INITIAL FALSE NO-UNDO 
    GET.
    SET. 
    
    /*------------------------------------------------------------------------------
        Purpose: Create a temptable row
        Notes:   
        @param pcParameterScope The paramter scope 
        @param pcSourceType The source type
        @param pcSourceName The source name (fulltypename from class)
        @param pcMethodName The method name
        @param pcMethodModifier The method modifiere
        @param pcParameterName The parameter name
        @param plMissingComment Is the comment missing in the comment of is the parameter commented but missing in code
        @param pcParameterComment is only a comment available without parameter
    ------------------------------------------------------------------------------*/
	METHOD PROTECTED VOID AddTempTableRow (pcParameterScope   AS CHARACTER,
	                                       pcSourceType       AS CHARACTER,
	                                       pcSourceName       AS CHARACTER,
	                                       pcMethodName       AS CHARACTER,
	                                       pcMethodModifier   AS CHARACTER,
	                                       pcParameterName    AS CHARACTER,
	                                       plMissingComment   AS LOGICAL,
	                                       pcParameterComment AS CHARACTER):
		
		DEFINE BUFFER ttMissingParameter FOR ttMissingParameter . 
		
		IF NOT CAN-FIND (ttMissingParameter WHERE ttMissingParameter.SourceName     = pcSourceName 
                                              AND ttMissingParameter.MethodName     = pcMethodName
                                              AND ttMissingParameter.ParameterName  = pcParameterName) THEN DO:
            CREATE ttMissingParameter.

            ASSIGN ttMissingParameter.ParameterScope   = pcParameterScope
                   ttMissingParameter.SourceType       = pcSourceType
                   ttMissingParameter.SourceName       = pcSourceName
                   ttMissingParameter.MethodName       = pcMethodName
                   ttMissingParameter.MethodModifier   = pcMethodModifier
                   ttMissingParameter.ParameterName    = pcParameterName
                   ttMissingParameter.MissingComment   = plMissingComment
                   ttMissingParameter.ParameterComment = pcParameterComment
                   .
         END.

	END METHOD .

    /*------------------------------------------------------------------------------
        Purpose: Create all missing method parameter
        Notes:   
        @param pcSourceType The eUnit Source type
        @param pcSourceName The eUnit source name
    ------------------------------------------------------------------------------*/
	METHOD PROTECTED VOID CreateMissingMethodParameter (pcSourceType AS CHARACTER,
	                                                    pcSourceName AS CHARACTER):
	                                                        
        DEFINE VARIABLE lcComment       AS LONGCHAR NO-UNDO.
        DEFINE VARIABLE lcSiganture     AS LONGCHAR NO-UNDO.
        DEFINE VARIABLE lMissingComment AS LOGICAL  NO-UNDO.
        	    
        FOR EACH eMethod ON ERROR UNDO, THROW:
            COPY-LOB eMethod.MethodComment TO lcComment.
            
            THIS-OBJECT:LogMissingParameterComment (lcComment,
                                                    "METHOD":U,
                                                    pcSourceType, 
                                                    pcSourceName,
                                                    REPLACE (ClassDocumentationHelper:ShortSignatureParser(eMethod.Signature, "":U), "  ":U, " ":U),
                                                    eMethod.Modifier,
                                                    eMethod.GUID).
             
            THIS-OBJECT:LogMissingParameter (lcComment,
                                             "METHOD":U,
                                             pcSourceType, 
                                             pcSourceName,
                                             REPLACE (ClassDocumentationHelper:ShortSignatureParser(eMethod.Signature, "":U), "  ":U, " ":U),
                                             eMethod.Modifier,
                                             eMethod.GUID).
            
            THIS-OBJECT:LogMissingReturns (lcComment,
                                           "METHOD":U,
                                           pcSourceType, 
                                           pcSourceName,
                                           REPLACE (ClassDocumentationHelper:ShortSignatureParser(eMethod.Signature, "":U), "  ":U, " ":U),
                                           eMethod.Modifier,
                                           eMethod.ReturnType).
        END. 

	END METHOD.
	
	/*------------------------------------------------------------------------------
        Purpose: Create all missing constructor parameter
        Notes:   
        @param pcSourceType The eUnit Source type
        @param pcSourceName The eUnit source name
    ------------------------------------------------------------------------------*/
    METHOD PROTECTED VOID CreateMissingConstructorParameter (pcSourceType AS CHARACTER,
                                                             pcSourceName AS CHARACTER):
                                                            
        DEFINE VARIABLE lcComment       AS LONGCHAR NO-UNDO.
        DEFINE VARIABLE lcSiganture     AS LONGCHAR NO-UNDO.
        DEFINE VARIABLE lMissingComment AS LOGICAL  NO-UNDO.
                
        FOR EACH eConstructor ON ERROR UNDO, THROW:
            COPY-LOB eConstructor.ConstructorComment TO lcComment.
            
            THIS-OBJECT:LogMissingParameterComment (lcComment,
                                                    "CONSTRUCTOR":U,
                                                    pcSourceType, 
                                                    pcSourceName,
                                                    ClassDocumentationHelper:ShortSignatureParser(eConstructor.Signature, "":U),
                                                    eConstructor.Modifier,
                                                    eConstructor.GUID).
            
            THIS-OBJECT:LogMissingParameter (lcComment,
                                             "CONSTRUCTOR":U,
                                             pcSourceType, 
                                             pcSourceName,
                                             ClassDocumentationHelper:ShortSignatureParser(eConstructor.Signature, "":U),
                                             eConstructor.Modifier,
                                             eConstructor.GUID).
        END. 
        
    END METHOD.
    
    /*------------------------------------------------------------------------------
        Purpose: Create all missing event parameter
        Notes:   
        @param pcSourceType The eUnit Source type
        @param pcSourceName The eUnit source name
    ------------------------------------------------------------------------------*/
    METHOD PROTECTED VOID CreateMissingEventParameter (pcSourceType AS CHARACTER,
                                                       pcSourceName AS CHARACTER):
                                                            
        DEFINE VARIABLE lcComment       AS LONGCHAR NO-UNDO.
        DEFINE VARIABLE lcSiganture     AS LONGCHAR NO-UNDO.
        DEFINE VARIABLE lMissingComment AS LOGICAL  NO-UNDO.
                
        FOR EACH eEvent ON ERROR UNDO, THROW:
            COPY-LOB eEvent.EventComment TO lcComment.
            
            
            THIS-OBJECT:LogMissingParameterComment (lcComment,
                                                    "CONSTRUCTOR":U,
                                                    pcSourceType, 
                                                    pcSourceName,
                                                    eEvent.EventName,
                                                    eEvent.Modifier,
                                                    eEvent.GUID).
             
            THIS-OBJECT:LogMissingParameter (lcComment,
                                             "CONSTRUCTOR":U,
                                             pcSourceType, 
                                             pcSourceName,
                                             eEvent.EventName,
                                             eEvent.Modifier,
                                             eEvent.GUID).
        END. 

    END METHOD.
    
    /*------------------------------------------------------------------------------
        Purpose: Start the parameter validation
        Notes:   This method is invoked by the start procedure 
                 Consultingwerk/Studio/SmartDox/generate-parameter-reference.p
        @param poParameter A Consultingwerk.Studio.SmartDox.IParameterCommentValidatorParameter parameter object
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC VOID CommentValidatorStart (poParameter AS IParameterCommentValidatorParameter):
        DEFINE VARIABLE lok         AS LOGICAL   NO-UNDO.
        DEFINE VARIABLE lcComment   AS LONGCHAR  NO-UNDO.
        DEFINE VARIABLE cSourceType AS CHARACTER NO-UNDO.  
        DEFINE VARIABLE cSourceName AS CHARACTER NO-UNDO.

        IF THIS-OBJECT:Verbose THEN 
            MESSAGE "[ParamterCommentValidator] Getting list of files":U .
        
        Consultingwerk.Util.FileHelper:GetFileList (poParameter:SourceDir,
                                                    "*.xml":U,
                                                    OUTPUT TABLE ttFileNames BY-REFERENCE) .
        
        IF THIS-OBJECT:Verbose THEN 
            MESSAGE "[ParamterCommentValidator] Done":U  .
        
        oParser = NEW ClassDocumentationParser () .
        
        FOR EACH ttFileNames ON ERROR UNDO, THROW:
            IF THIS-OBJECT:Verbose THEN 
                MESSAGE "[ParamterCommentValidator]":U ttFileNames.FileName.

            DATASET dsClassDocumentation:EMPTY-DATASET ().
            oParser:ParseClassDocumentation (ttFileNames.FileName,
                                             INPUT-OUTPUT DATASET dsClassDocumentation BY-REFERENCE).

            FIND FIRST eUnit.
            
            IF eUnit.IsInterface = TRUE THEN 
                ASSIGN cSourceType = "INTERFACE":U.
            ELSE 
                ASSIGN cSourceType = "CLASS":U.
            
            ASSIGN cSourceName = SUBSTITUTE ("&1.&2":U, eUnit.PackageName, eUnit.ClassName).
            
            THIS-OBJECT:CreateMissingMethodParameter (cSourceType, cSourceName).
            THIS-OBJECT:CreateMissingConstructorParameter (cSourceType, cSourceName).
            THIS-OBJECT:CreateMissingEventParameter (cSourceType, cSourceName).
        END. 
        
    END METHOD .

    /*------------------------------------------------------------------------------
        Purpose: Returns the Temp-Table with the results of the validator 
        Notes:   
        @param ttMissingParameter OUTPUT TABLE The Temp-Table with the results of the validator
    ------------------------------------------------------------------------------*/
	METHOD PUBLIC VOID GetResult (OUTPUT TABLE ttMissingParameter):
		
		/* noop */

	END METHOD .

    /*------------------------------------------------------------------------------
        Purpose: Log all parameters without descriptions 
        Notes:   
        @param plcComment the comment value
        @param pcParameterScope the method scope
        @param pcSourceType the source type (fulltypename)
        @param pcSourceName the source name
        @param pcMethodName the name from th emethod
        @param pcMethodModifier the modiefiere from the method
        @param pcGUID the parent GUID 
    ------------------------------------------------------------------------------*/
	METHOD PROTECTED VOID LogMissingParameterComment (plcComment        AS LONGCHAR,
	                                                  pcParameterScope  AS CHARACTER,
	                                                  pcSourceType      AS CHARACTER,
	                                                  pcSourceName      AS CHARACTER, 
	                                                  pcMethodName      AS CHARACTER,
	                                                  pcMethodModifier  AS CHARACTER,
	                                                  pcGUID            AS CHARACTER):
	                                                  
	    DEFINE VARIABLE iCount           AS INTEGER    NO-UNDO.
	    DEFINE VARIABLE lcLine           AS LONGCHAR   NO-UNDO.
	    DEFINE VARIABLE lcTempLine       AS LONGCHAR   NO-UNDO.
	    DEFINE VARIABLE lMissingComment  AS LOGICAL    NO-UNDO.
	   	
	   	FOR EACH eParameter WHERE eParameter.ParentGUID = pcGUID ON ERROR UNDO, THROW:
	   	    
	   	    ASSIGN lMissingComment = TRUE .
	   	       
            DO iCount = 1 TO NUM-ENTRIES (plcComment, CHR (10)) ON ERROR UNDO, THROW:
                ASSIGN lcLine = TRIM (ENTRY (iCount, plcComment, CHR (10))).
                  
                IF lcLine BEGINS "@param":U THEN DO:
                    ASSIGN lcTempLine = TRIM (SUBSTRING (lcLine, INDEX (lcLine, "@param":U) + 6)).
                    
                    ASSIGN lcTempLine = ENTRY (1, lcTempLine, " ":U).
                    
                    IF lcTempLine = eParameter.Name THEN DO:
                        ASSIGN lMissingComment = ? .
                        LEAVE.
                    END. 
                END.
                
            END.
            
            IF lMissingComment <> ? THEN DO:
                THIS-OBJECT:AddTempTableRow (pcParameterScope,
                                             pcSourceType,
                                             pcSourceName,
                                             pcMethodName,
                                             pcMethodModifier,
                                             eParameter.Name,
                                             lMissingComment,
                                             "":U).
            END.
        END.

	END METHOD .    
    
    /*------------------------------------------------------------------------------
        Purpose: Log all comment lines without parameters 
        Notes:
        @param plcComment the comment value
        @param pcParameterScope the method scope
        @param pcSourceType the source type (fulltypename)
        @param pcSourceName the source name
        @param pcMethodName the name from th emethod
        @param pcMethodModifier the modiefiere from the method
        @param pcGUID the parent GUID 
    ------------------------------------------------------------------------------*/
    METHOD PROTECTED VOID LogMissingParameter (plcComment        AS LONGCHAR,
                                               pcParameterScope  AS CHARACTER,
                                               pcSourceType      AS CHARACTER,
                                               pcSourceName      AS CHARACTER, 
                                               pcMethodName      AS CHARACTER,
                                               pcMethodModifier  AS CHARACTER,
                                               pcGUID            AS CHARACTER):
                                                    
        DEFINE VARIABLE iCount             AS INTEGER    NO-UNDO.
        DEFINE VARIABLE lcLine             AS LONGCHAR   NO-UNDO.
        DEFINE VARIABLE lcTempLine         AS LONGCHAR   NO-UNDO.
        DEFINE VARIABLE lMissingParameter  AS LOGICAL    NO-UNDO.
        DEFINE VARIABLE cTempParameter     AS CHARACTER  NO-UNDO.
        DEFINE VARIABLE cParameter         AS CHARACTER  NO-UNDO.
           
        DO iCount = 1 TO NUM-ENTRIES (plcComment, CHR (10)) ON ERROR UNDO, THROW:
            
            ASSIGN lcLine            = TRIM (ENTRY (iCount, plcComment, CHR (10)))
                   lMissingParameter = FALSE
                   .
                   
            IF lcLine BEGINS "@param":U THEN DO:
                ASSIGN lcTempLine = TRIM (SUBSTRING (lcLine, INDEX (lcLine, "@param":U) + 6)).

                ASSIGN lcTempLine = ENTRY (1, lcTempLine, " ":U).

                FOR EACH eParameter WHERE eParameter.ParentGUID = pcGUID ON ERROR UNDO, THROW:
                    IF lcTempLine = eParameter.Name THEN DO:
                        ASSIGN lMissingParameter = ? .
                        LEAVE.
                    END.
                END.
                
                IF lMissingParameter <> ? THEN DO:
                    THIS-OBJECT:AddTempTableRow (pcParameterScope,
                                                 pcSourceType,
                                                 pcSourceName,
                                                 pcMethodName,
                                                 pcMethodModifier,
                                                 STRING (lcTempLine),
                                                 lMissingParameter,
                                                 STRING (lcLine)).
                END.
            END.
        END.
        
    END METHOD .
    
    /*------------------------------------------------------------------------------
        Purpose: Write the TempTable to the xml file 
        Notes:   
        @param pcTargetFile set the output into targetfile
    ------------------------------------------------------------------------------*/
	METHOD PUBLIC VOID ExportToFile (pcTargetFile AS CHARACTER):
		
		TEMP-TABLE ttMissingParameter:WRITE-XML ("FILE":U, pcTargetFile, TRUE).

	END METHOD .    

    /*------------------------------------------------------------------------------
        Purpose: Log all missing returns comments
        Notes:   
        @param plcComment the comment value
        @param pcParameterScope the method scope
        @param pcSourceType the source type (fulltypename)
        @param pcSourceName the source name
        @param pcMethodName the name from th emethod
        @param pcMethodModifier the modiefiere from the method
        @param pcReturnType the returntype from th emethod
    ------------------------------------------------------------------------------*/
	METHOD PROTECTED VOID LogMissingReturns (plcComment        AS LONGCHAR,
                                             pcParameterScope  AS CHARACTER,
                                             pcSourceType      AS CHARACTER,
                                             pcSourceName      AS CHARACTER, 
                                             pcMethodName      AS CHARACTER,
                                             pcMethodModifier  AS CHARACTER,
	                                         pcReturnType      AS CHARACTER):
	                                             
	    DEFINE VARIABLE iCount                      AS INTEGER    NO-UNDO.
	    DEFINE VARIABLE lcLine                      AS LONGCHAR   NO-UNDO.
	    DEFINE VARIABLE lMissingParameter           AS LOGICAL    NO-UNDO INIT ? .
        DEFINE VARIABLE lcTempLine                  AS LONGCHAR   NO-UNDO.
        DEFINE VARIABLE lExistReturnCommentLine     AS LOGICAL    NO-UNDO INIT FALSE.
	    
        DO iCount = 1 TO NUM-ENTRIES (plcComment, CHR (10)) ON ERROR UNDO, THROW:
           ASSIGN lcLine            = TRIM (ENTRY (iCount, plcComment, CHR (10)))
                  .
           
           IF lcLine BEGINS "@return":U THEN DO:
               ASSIGN lExistReturnCommentLine = TRUE. 
               IF pcReturnType = "":U THEN DO:
                    ASSIGN lMissingParameter = FALSE.
                    LEAVE.
               END.
           END.
        END. 		

        IF lMissingParameter <> ? THEN DO:
            /* Sebastian D?ngel, Consultingwerk Ltd. 10.04.2013
               Logged all @return commentline, when the mehtod has not an returntype*/
            THIS-OBJECT:AddTempTableRow (pcParameterScope,
                                         pcSourceType,
                                         pcSourceName,
                                         pcMethodName,
                                         pcMethodModifier,
                                         "@RETURN":U,
                                         FALSE,
                                         STRING (lcLine)).
        END.                                  
        ELSE DO:
            /* Sebastian D?ngel, Consultingwerk Ltd. 10.04.2013
               Logged all missing Returntypes without description*/
            IF pcReturnType <> "":U AND lExistReturnCommentLine = FALSE THEN DO:
                THIS-OBJECT:AddTempTableRow (pcParameterScope,
                                             pcSourceType,
                                             pcSourceName,
                                             pcMethodName,
                                             pcMethodModifier,
                                             "@RETURN":U,
                                             TRUE,
                                             "":U).
            END. 
        END. 
            
            
	END METHOD .

END CLASS.




© 2015 - 2025 Weber Informatics LLC | Privacy Policy