_cmdname()
QNX SDP8.0C Library ReferenceAPIDeveloper
Find the path used to invoke the current process
Synopsis:
#include <process.h>
char * _cmdname( char * buff );
Arguments:
- buff
- NULL, or a pointer to a buffer in which the function can store the path. To determine the size required for the buffer, call fpathconf() or pathconf() with an argument of _PC_PATH_MAX, then add 1 for the terminating null character.
Library:
libc
Use the -l c option to qcc to link against this library. This library is usually included automatically.
Description:
The _cmdname() function determines the full path that the current process was invoked from. If buff isn't NULL, _cmdname() copies the path into the buffer that buff points to.
Returns:
A pointer to the pathname used to load the process, or NULL if an error occurred.
Note: 
Don't change the string that the returned value points to if you passed
NULL for the buff parameter.
Examples:
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <limits.h>
#include <process.h>
int main( void )
{
    size_t maximum_path;
    char *buff;
    
    maximum_path = (size_t) pathconf( "/", _PC_PATH_MAX );
    buff = (char* )malloc( maximum_path );
    if( _cmdname( buff ) ) {
        printf( "I'm \"%s\".\n", buff );
    } else {
        perror( "_cmdname() failed" );
        free (buff);
        return EXIT_FAILURE;
    }
    
    free (buff);
    return EXIT_SUCCESS;
}
If this code is compiled into an executable named foo:
# ls -F /home/xyzzy/bin/foo
foo*
# /home/xyzzy/bin/foo
I'm "/home/xyzzy/bin/foo".
Classification:
| Safety: | |
|---|---|
| Cancellation point | No | 
| Signal handler | No | 
| Thread | Yes | 
Page updated: 
