FLAMCLE/P-API
Command Line Executor/Parser Application Programming Interface
CLP Functions

The function provided by CLP. More...

Functions

const char * pcClpVersion (const int l, const int s, char *b)
 Get version information. More...
 
const char * pcClpAbout (const int l, const int s, char *b)
 Get about information. More...
 
void * pvClpOpen (const int isCas, const int isPfl, const int isEnv, const int siMkl, const char *pcOwn, const char *pcPgm, const char *pcBld, const char *pcCmd, const char *pcMan, const char *pcHlp, const int isOvl, const TsClpArgument *psTab, void *pvDat, FILE *pfHlp, FILE *pfErr, FILE *pfSym, FILE *pfScn, FILE *pfPrs, FILE *pfBld, const char *pcDep, const char *pcOpt, const char *pcEnt, TsClpError *psErr, void *pvGbl, void *pvF2S, TfF2S *pfF2S, void *pvSaf, TfSaf *pfSaf)
 Open command line parser. More...
 
void vdClpReset (void *pvHdl)
 Reset command line parser. More...
 
int siClpParsePro (void *pvHdl, const char *pcSrc, const char *pcPro, const int isChk, char **ppLst)
 Parse the property list. More...
 
int siClpParseCmd (void *pvHdl, const char *pcSrc, const char *pcCmd, const int isChk, const int isPwd, int *piOid, char **ppLst)
 Parse the command line. More...
 
int siClpSyntax (void *pvHdl, const int isSkr, const int isMin, const int siDep, const char *pcPat)
 Print command line syntax. More...
 
const char * pcClpInfo (void *pvHdl, const char *pcPat)
 Give help message for given path. More...
 
int siClpHelp (void *pvHdl, const int siDep, const char *pcPat, const int isAli, const int isMan)
 Print help for command line syntax. More...
 
int siClpDocu (void *pvHdl, FILE *pfDoc, const char *pcPat, const char *pcNum, const char *pcKnd, const int isCmd, const int isDep, const int isMan, const int isAnc, const int isNbr, const int isIdt, const int isPat, const unsigned int uiLev)
 Generate documentation for command line syntax. More...
 
int siClpPrint (void *pvHdl, const char *pcFil, const char *pcNum, const char *pcKnd, const int isCmd, const int isDep, const int isAnc, const int isNbr, const int isShl, const int isIdt, const int isPat, const unsigned int uiLev, const int siPs1, const int siPs2, const int siPr3, void *pvPrn, TfClpPrintPage *pfPrn)
 Generate documentation using a callback function. More...
 
int siClpProperties (void *pvHdl, const int siMtd, const int siDep, const char *pcPat, FILE *pfOut)
 Generate properties. More...
 
int siClpLexemes (void *pvHdl, FILE *pfOut)
 Print the lexems of the command line compiler. More...
 
int siClpGrammar (void *pvHdl, FILE *pfOut)
 Print the grammar of the command line compiler. More...
 
void vdClpClose (void *pvHdl, const int siMtd)
 Close the command line parser. More...
 
void * pvClpAlloc (void *pvHdl, void *pvPtr, int siSiz, int *piInd)
 Allocate memory in CLP structure. More...
 
char * pcClpError (int siErr)
 Provides error message. More...
 

Detailed Description

The function provided by CLP.

Function Documentation

◆ pcClpVersion()

const char* pcClpVersion ( const int  l,
const int  s,
char *  b 
)

Get version information.

The function returns the version information for this library

Parameters
[in]lLevel of visible hierarchy in the first 2 numbers of the string the number can later be used to better visualize the hierarchy
[in]sSize of the provided string buffer (including space for null termination)
[in,out]bBuffer for the version string. Must contain a null-terminated string. The version string will be concatenated. The size including the 0-byte is the limit. If (strlen(b)==s-1) then more space is required for the complete version string. A good size for the version string is 128 byte.
Returns
Pointer to a null-terminated version string (return(b))

◆ pcClpAbout()

const char* pcClpAbout ( const int  l,
const int  s,
char *  b 
)

Get about information.

The function returns the about information for this library

Parameters
[in]lLevel of visible hierarchy in the first 2 numbers of the string the number can later be used to better visualize the hierarchy
[in]sSize of the provided string buffer (including space for null termination)
[in,out]bBuffer for the about string. Must contain a null-terminated string. The about string will be concatenated. The size including the 0-byte is the limit. If (strlen(b)==s-1) then more space is required for the complete about string. A good size for the about string is 512 byte.
Returns
pointer to a null-terminated about string (return(b))

◆ pvClpOpen()

void* pvClpOpen ( const int  isCas,
const int  isPfl,
const int  isEnv,
const int  siMkl,
const char *  pcOwn,
const char *  pcPgm,
const char *  pcBld,
const char *  pcCmd,
const char *  pcMan,
const char *  pcHlp,
const int  isOvl,
const TsClpArgument psTab,
void *  pvDat,
FILE *  pfHlp,
FILE *  pfErr,
FILE *  pfSym,
FILE *  pfScn,
FILE *  pfPrs,
FILE *  pfBld,
const char *  pcDep,
const char *  pcOpt,
const char *  pcEnt,
TsClpError psErr,
void *  pvGbl,
void *  pvF2S,
TfF2S pfF2S,
void *  pvSaf,
TfSaf pfSaf 
)

Open command line parser.

The function uses the argument table and corresponding structure and creates the handle for the command line parser (FLAMCLP)

Parameters
[in]isCasBoolean to enable case sensitive parsing of keywords (recommended is FALSE)
[in]isPflBoolean to enable parameter files per object and overlay (recommended is TRUE(1), if you provide 2 the parameter file is not parsed but the syntax is accepted)
[in]isEnvBoolean to enable replacement of environment variables (recommended is TRUE)
[in]siMklInteger defining the minimal key word length (siMkl<=0 --> full length, no auto abbreviation)
[in]pcOwnString constant containing the owner name for the root in the path ("limes")
[in]pcPgmString constant containing the program name for the root in the path ("flcl")
[in]pcBldString constant containing the build/version string for replacement
[in]pcCmdString constant containing the command name for the root in the path ("CONV")
[in]pcManString constant containing the manual page for this command (converted on EBCDIC systems)
[in]pcHlpString constant containing the help message for this command (converted on EBCDIC systems)
[in]isOvlBoolean if TRUE the main table (psTab) is a overlay else it will be interpreted as object
[in]psTabPointer to the parameter table defining the semantic of the command line
[out]pvDatPointer to the structure where the parsed values are stored (can be NULL if command line parsing not used)
[in]pfHlpPointer to the file used for help messages (if not set then stderr)
[in]pfErrPointer to the file used for error messages or NULL for no printing
[in]pfSymPointer to the file used for symbol table trace or NULL for no printing
[in]pfScnPointer to the file used for scanner trace or NULL for no printing
[in]pfPrsPointer to the file used for parser trace or NULL for no printing
[in]pfBldPointer to the file used for builder trace or NULL for no printing
[in]pcDepString used for hierarchical print outs (help, errors, trace (recommended S_IDT="--|"))
[in]pcOptString used to separate options (recommended "/")
[in]pcEntString used to separate list entries (recommended ",")
[out]psErrPointer to the error structure. If the pointer != NULL the structure is filled with pointers to certain error information in the CLP handle. If pfErr defined all error information are printed by CLP. In this case these structure is not required. If pfErr==NULL you can use these structure to gather all error information of CLP in memory. The pointer are only valid until vsClpClose().
[in]pvGblPointer to the global handle as black box given over CleExecute
[in]pvF2SPointer to a handle which can be used in file 2 string callback function (if not required then NULL)
[in]pfF2SCallback function which reads a file into a variable null-terminated string in memory (if NULL then default implementation is used)
[in]pvSafPointer to a handle which can be used in authorization callback function (if not required then NULL)
[in]pfSafCallback function to authorize each write to CLP structure or NULL for no additional check
Returns
void pointer to the memory containing the handle

◆ vdClpReset()

void vdClpReset ( void *  pvHdl)

Reset command line parser.

Required after an error which was handled by the calling application to parse properties or commands correctly

Parameters
[in,out]pvHdlPointer to the corresponding handle created with pvClpOpen

◆ siClpParsePro()

int siClpParsePro ( void *  pvHdl,
const char *  pcSrc,
const char *  pcPro,
const int  isChk,
char **  ppLst 
)

Parse the property list.

The function parses the property list

Attention: Property parsing only effects the default values in the symbol table and don't write anything to the CLP structure. You must use the same CLP handle for property and command line parsing.

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]pcSrcPointer to a null-terminated string containing the source name for the property list Property list are mainly taken from a file. It is useful to provide this file name for error printing
[in]pcProPointer to a null-terminated string containing the property list for parsing
[in]isChkBoolean to enable (TRUE) or disable (FALSE) validation of the root in path (if FALSE then other properties are ignored, if TRUE then other properties are not possible)
[out]ppLstPointer to the parsed parameter list (NULL = no list provided) in the CLP handle
Returns
signed integer with CLP_OK (0 - nothing parsed) or an error code (CLPERR_xxxxxx (<0)) or the amount of parsed entities (>0)

◆ siClpParseCmd()

int siClpParseCmd ( void *  pvHdl,
const char *  pcSrc,
const char *  pcCmd,
const int  isChk,
const int  isPwd,
int *  piOid,
char **  ppLst 
)

Parse the command line.

The function parses the command line and returns OK or the error code and error position (byte offset)

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]pcSrcPointer to a null-terminated string containing the source name for the command line If the command line taken from a file it is useful to provide this file name for error printing else use NULL.
[in]pcCmdPointer to a null-terminated string containing the command for parsing
[in]isChkBoolean to enable (TRUE) or disable (FALSE) validation of minimum number of entries
[in]isPwdBoolean to enable (TRUE) or disable (FALSE) '*** SECRET ***' replacement in parsed parameter list below
[out]piOidIf this pointer is set and the main table is an overlay the corresponding object identifier is returned
[out]ppLstPointer to the parsed parameter list (NULL = no list provided) in the CLP handle
Returns
signed integer with CLP_OK (0 - nothing parsed) or an error code (CLPERR_xxxxxx (<0)) or the amount of parsed entities (>0)

◆ siClpSyntax()

int siClpSyntax ( void *  pvHdl,
const int  isSkr,
const int  isMin,
const int  siDep,
const char *  pcPat 
)

Print command line syntax.

The function prints the command line syntax

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]isSkrIf true the syntax will be printed in structured form
[in]isMinIf true each element will be prefixed with '!' for required and '?' for optional
[in]siDepDepth of next levels to display (0-Nothing, 1-One Level, 2-Two Level, ..., <9-All)
[in]pcPatPath (root.input...) to limit syntax to a certain level
Returns
signed integer with CLP_OK(0) or an error code (CLPERR_xxxxxx)

◆ pcClpInfo()

const char* pcClpInfo ( void *  pvHdl,
const char *  pcPat 
)

Give help message for given path.

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]pcPatPath (root.input...) to limit help to a certain level
Returns
string to message or emty message if error

◆ siClpHelp()

int siClpHelp ( void *  pvHdl,
const int  siDep,
const char *  pcPat,
const int  isAli,
const int  isMan 
)

Print help for command line syntax.

The function prints the help strings for the command line syntax

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]pcPatPath (root.input...) to limit help to a certain level
[in]siDepDepth of next levels to display (0-Manpage, 1-One Level, 2-Two Level, ..., <9-All)
[in]isAliPrint also aliases (if FALSE help don't show aliases)
[in]isManPrint manpage if no further arguments are available
Returns
signed integer with CLP_OK(0) or an error code (CLPERR_xxxxxx)

◆ siClpDocu()

int siClpDocu ( void *  pvHdl,
FILE *  pfDoc,
const char *  pcPat,
const char *  pcNum,
const char *  pcKnd,
const int  isCmd,
const int  isDep,
const int  isMan,
const int  isAnc,
const int  isNbr,
const int  isIdt,
const int  isPat,
const unsigned int  uiLev 
)

Generate documentation for command line syntax.

The function generates the documentation for a whole command or if a path is assigned a part of the command. The format will be ASCIIDOC. If one of the arguments has a manual page (detailed description) a headline with numbering dependent from the keyword is generated. After a generated synopsis including the help message, the path, the type and the syntax the detailed description (pcMan) is printed. If one of theses arguments has no manual page then a bullet list with the keyword, type, syntax and help message will be built.

The headline will be 'number ARGUMENT keyword'. For arguments the headline level 3 '~' is used. The same is valid for constant definitions, but in this case the headline level 4 '^' and the key word 'CONSTANT' in Headline or 'SELECTIONS' in bullet list is used.

Numbering of headlines for doc type book can be enabled or disabled. If a level given (>0) then the headlines are prefixed with this amount of '=' for arguments and with one '=' more for constants or selections. A valid minimum level would be 3 and the maximum should not greater then 5.

The manual page for the command is displayed with headline level 2 '-', if no manual page is available the message below is shown:

'No detailed description available for this command.'

The same is valid for objects and overlays, which means that at a minimum each command, overlay and object needs a detailed description of all normal arguments can be printed as bullet list.

There will be one level of headlines left for the CleExecute, where the program itself, the commands, built-in functions and the appendix are separated.

If only one level of depth is used for printing, then doc type book (isMan==FALSE) or manual page (isMan=TRUE) can be selected. With doc type book the corresponding section of the user manual is generated, with manual page option the asciidoc MANPAGE format is made.

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]pfDocFile handle used to write the documentation in ASCIIDOC format
[in]pcPatPath (root.input...) to limit documentation certain level
[in]pcNumLeading number for table of contents ("1.2." used or not used depend on isNbr, NULL pointer cause an error)
[in]pcKndQualifier for command/otherclp head line (Recommended: "COMMAND" or "STRING" NULL pointer cause an error)
[in]isCmdIf TRUE for command and FALSE for other CLP strings (required for anchor generation).
[in]isDepIf TRUE then all deeper parts are printed if FALSE then not.
[in]isManIf TRUE then doc type MANPAGE will be generated else doc type book will be used. (isMan==TRUE results automatically in isDep==FALSE)
[in]isAncBoolean to enable write of generated anchors for each command (only for doc type book)
[in]isNbrBoolean to enable header numbering for generated documentation (only for doc type book)
[in]isIdtBoolean to enable printing of generated index terms (only for doc type book)
[in]isPatBoolean to enable printing of path as part of the synopsis (only for doc type book)
[in]uiLevIf > 0 then headlines are written with this amount of '=' in front instead of underlining (only for doc type book)
Returns
signed integer with CLP_OK(0) or an error code (CLPERR_xxxxxx)

◆ siClpPrint()

int siClpPrint ( void *  pvHdl,
const char *  pcFil,
const char *  pcNum,
const char *  pcKnd,
const int  isCmd,
const int  isDep,
const int  isAnc,
const int  isNbr,
const int  isShl,
const int  isIdt,
const int  isPat,
const unsigned int  uiLev,
const int  siPs1,
const int  siPs2,
const int  siPr3,
void *  pvPrn,
TfClpPrintPage pfPrn 
)

Generate documentation using a callback function.

This function works like siClpDocu, but it gives each page to a callback function and don't print it to a certain file.

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]pcFilPrefix for file name building
[in]pcNumLeading number for table of contents ("1.2." used or not used depend on isNbr, NULL pointer cause an error)
[in]pcKndQualifier for command/otherclp head line (Recommended: "COMMAND" or "STRING" NULL pointer cause an error)
[in]isCmdIf TRUE for command and FALSE for other CLP strings (required for anchor generation).
[in]isDepIf TRUE then all deeper parts are printed if FALSE then not.
[in]isAncBoolean to enable write of generated anchors for each command (only for doc type book)
[in]isNbrBoolean to enable header numbering for generated documentation (only for doc type book)
[in]isShlBoolean to enable short headline without type specification (only for doc type book)
[in]isIdtBoolean to enable printing of generated index terms (only for doc type book)
[in]isPatBoolean to enable printing of path as part of the synopsis (only for doc type book)
[in]uiLevIf > 0 then headlines are written with this amount of '=' in front instead of underlining (only for doc type book)
[in]siPs1Character to separate parts to build filename outside command path (only for doc type book)
[in]siPs2Character to separate parts to build filename inside command path (only for doc type book)
[in]siPr3Character to replace non alpha-numerical characters in file names (only for doc type book)
[in]pvPrnHandle for the print callback function (created with TfCleOpenPrint (opnHtmlDoc))
[in,out]pfPrnPointer to the callback function TfClpPrintPage (prnHtmlDoc)
Returns
signed integer with CLP_OK(0) or an error code (CLPERR_xxxxxx)

◆ siClpProperties()

int siClpProperties ( void *  pvHdl,
const int  siMtd,
const int  siDep,
const char *  pcPat,
FILE *  pfOut 
)

Generate properties.

The function produces a property list with the current default values

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]siMtdMethod for property printing (0-ALL, 1-Defined, 2-All but not defined as comment)
[in]siDepDepth of next levels to print (1-One Level, 2-Two Level, ..., <9-All)
[in]pcPatPath (root.input...) to limit the amount of properties
[in]pfOutFile pointer to write the property list (if NULL then pfHlp of FLAMCLP is used)
Returns
signed integer with CLP_OK(0) or an error code (CLPERR_xxxxxx)

◆ siClpLexemes()

int siClpLexemes ( void *  pvHdl,
FILE *  pfOut 
)

Print the lexems of the command line compiler.

The function prints the regular expressions of the command line compiler

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]pfOutPointer to the file descriptor used to print the regular expressions
Returns
signed integer with CLP_OK(0) or an error code (CLPERR_xxxxxx)

◆ siClpGrammar()

int siClpGrammar ( void *  pvHdl,
FILE *  pfOut 
)

Print the grammar of the command line compiler.

The function prints the context free grammar of the command line compiler

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]pfOutPointer to the file descriptor used to print the grammar
Returns
signed integer with CLP_OK(0) or an error code (CLPERR_xxxxxx)

◆ vdClpClose()

void vdClpClose ( void *  pvHdl,
const int  siMtd 
)

Close the command line parser.

The function releases the allocated resources in the handle. If dynamic allocation of data fields used in the CLP structure, you can close the CLP handle except the list of dynamic allocated pointer in the CLP structure. If the siMtd is set to CLPCLS_MTD_KEP the CLP handle is still open and can later be used to free the remaining pointers of the CLP structure. If the method EXC (except) used, then the CLP handle is closed and the application must free the allocated memory in the CLP structure. This is useful if you need the CLP no longer but the CLP data structure must be valid. You can later call the vdClpClose function again to release the dynamic allocated data fields of the CLP structure with method keep.

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]siMtdDefine the close method (EXC/KEP/ALL)

◆ pvClpAlloc()

void* pvClpAlloc ( void *  pvHdl,
void *  pvPtr,
int  siSiz,
int *  piInd 
)

Allocate memory in CLP structure.

This function allocates memory for the CLP structure and can be used to extend the structure where dynamic array or strings must be extended. If the pointer (pvPtr) not NULL and not known by CLP the function pvClpAlloc is called like pvPtr=NULL. This mechanism can be used to use a pointer to a literal or a static variable in the initialization phase

Parameters
[in]pvHdlPointer to the corresponding handle created with pvClpOpen
[in]pvPtrPointer of the dynamic allocated area or NULL if it is a new one
[in]siSizRequired size for the dynamic area
[in,out]piIndPointer to the index of the memory area or NULL (improves performance)
Returns
Pointer to allocated and initialized memory or NULL if error

◆ pcClpError()

char* pcClpError ( int  siErr)

Provides error message.

The function provides a error message for the corresponding error code

Parameters
[in]siErrError code from parser