forked from Imagelibrary/rtems
2009-08-05 Joel Sherrill <joel.sherrill@oarcorp.com>
* libmisc/bspcmdline/bspcmdline.h, libmisc/bspcmdline/bspcmdline_get.c, libmisc/bspcmdline/bspcmdline_getparam.c, libmisc/bspcmdline/bspcmdline_getparamraw.c, libmisc/bspcmdline/bspcmdline_getparamrhs.c: New files. Missed in previous commit.
This commit is contained in:
@@ -1,3 +1,11 @@
|
|||||||
|
2009-08-05 Joel Sherrill <joel.sherrill@oarcorp.com>
|
||||||
|
|
||||||
|
* libmisc/bspcmdline/bspcmdline.h, libmisc/bspcmdline/bspcmdline_get.c,
|
||||||
|
libmisc/bspcmdline/bspcmdline_getparam.c,
|
||||||
|
libmisc/bspcmdline/bspcmdline_getparamraw.c,
|
||||||
|
libmisc/bspcmdline/bspcmdline_getparamrhs.c: New files.
|
||||||
|
Missed in previous commit.
|
||||||
|
|
||||||
2009-08-05 Joel Sherrill <joel.sherrill@oarcorp.com>
|
2009-08-05 Joel Sherrill <joel.sherrill@oarcorp.com>
|
||||||
|
|
||||||
* Makefile.am, preinstall.am, libmisc/Makefile.am, wrapup/Makefile.am:
|
* Makefile.am, preinstall.am, libmisc/Makefile.am, wrapup/Makefile.am:
|
||||||
|
|||||||
127
cpukit/libmisc/bspcmdline/bspcmdline.h
Normal file
127
cpukit/libmisc/bspcmdline/bspcmdline.h
Normal file
@@ -0,0 +1,127 @@
|
|||||||
|
/**
|
||||||
|
* @file rtems/bspcmdline.h
|
||||||
|
*
|
||||||
|
* This include file contains all prototypes and specifications
|
||||||
|
* related to the BSP Command Line String and associated helper
|
||||||
|
* routines. The helpers are useful for locating command line
|
||||||
|
* type arguments (e.g. --mode) and their associated right
|
||||||
|
* hand side (e.g. FAST in --mode=FAST).
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* COPYRIGHT (c) 1989-2009.
|
||||||
|
* On-Line Applications Research Corporation (OAR).
|
||||||
|
*
|
||||||
|
* The license and distribution terms for this file may be
|
||||||
|
* found in the file LICENSE in this distribution or at
|
||||||
|
* http://www.rtems.com/license/LICENSE.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __BSP_COMMAND_LINE_h
|
||||||
|
#define __BSP_COMMAND_LINE_h
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @defgroup BSPCommandLine BSP Command Line Helpers
|
||||||
|
*
|
||||||
|
* The BSP Command Line Handler provides a set of routines which assist
|
||||||
|
* in examining and decoding the Command Line String passed to the BSP
|
||||||
|
* at boot time.
|
||||||
|
*/
|
||||||
|
/**@{*/
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Obtain Pointer to BSP Boot Command String
|
||||||
|
*
|
||||||
|
* This method returns a pointer to the BSP Boot Command String. It
|
||||||
|
* is as likely to be NULL as point to a string as most BSPs do not
|
||||||
|
* have a start environment that provides a boot string.
|
||||||
|
*
|
||||||
|
* @return This method returns the pointer to the BSP Boot Command String.
|
||||||
|
*/
|
||||||
|
const char *bsp_cmdline_get(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Obtain COPY of the Entire Matching Argument
|
||||||
|
*
|
||||||
|
* This method searches for the argument @a name in the BSP Boot Command
|
||||||
|
* String and returns a copy of the entire string associated with it in
|
||||||
|
* @a value up to a string of @a length. This will include the argument
|
||||||
|
* and any right hand side portion of the string. For example, one might
|
||||||
|
* be returned --mode=FAST if
|
||||||
|
* searching for --mode.
|
||||||
|
*
|
||||||
|
* @param[in] name is the arugment to search for
|
||||||
|
* @param[in] value points to where the contents will
|
||||||
|
* be placed if located.
|
||||||
|
* @param[in] length is the maximum length to copy
|
||||||
|
*
|
||||||
|
* @return This method returns NULL if not found and
|
||||||
|
* @a value if found.
|
||||||
|
*/
|
||||||
|
const char *bsp_cmdline_get_param(
|
||||||
|
const char *name,
|
||||||
|
char *value,
|
||||||
|
size_t length
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Obtain COPY of the Right Hand Side of the Matching Argument
|
||||||
|
*
|
||||||
|
* This method searches for the argument @a name in
|
||||||
|
* the BSP Boot Command String and returns the right hand side
|
||||||
|
* associated with it in @a value up to a maximum string @a length.
|
||||||
|
* This will NOT include the argument but only any right hand side
|
||||||
|
* portion of the string. * For example, one might be returned FAST if
|
||||||
|
* searching for --mode.
|
||||||
|
*
|
||||||
|
* @param[in] name is the arugment to search for
|
||||||
|
* @param[in] value points to where the contents will
|
||||||
|
* be placed if located.
|
||||||
|
* @param[in] length is the maximum length to copy
|
||||||
|
*
|
||||||
|
* @return This method returns NULL if not found and
|
||||||
|
* @a value if found.
|
||||||
|
*/
|
||||||
|
const char *bsp_cmdline_get_param_rhs(
|
||||||
|
const char *name,
|
||||||
|
char *value,
|
||||||
|
size_t length
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Obtain Pointer to the Entire Matching Argument
|
||||||
|
*
|
||||||
|
* This method searches for the argument @a name in
|
||||||
|
* the BSP Boot Command String and returns a pointer to the
|
||||||
|
* entire string associated with it. This will include the
|
||||||
|
* argument and any right hand side portion of the string.
|
||||||
|
* For example, one might be returned --mode=FAST if
|
||||||
|
* searching for --mode.
|
||||||
|
*
|
||||||
|
* @param[in] name is the arugment to search for
|
||||||
|
*
|
||||||
|
* @return This method returns NULL if not found and a pointer
|
||||||
|
* into the BSP Boot Command String if found.
|
||||||
|
*
|
||||||
|
* @note The pointer will be to the original BSP Command
|
||||||
|
* Line string. Exercise caution when using this.
|
||||||
|
*/
|
||||||
|
const char *bsp_cmdline_get_param_raw(
|
||||||
|
const char *name
|
||||||
|
);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**@}*/
|
||||||
|
#endif
|
||||||
19
cpukit/libmisc/bspcmdline/bspcmdline_get.c
Normal file
19
cpukit/libmisc/bspcmdline/bspcmdline_get.c
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
/*
|
||||||
|
* COPYRIGHT (c) 1989-2009.
|
||||||
|
* On-Line Applications Research Corporation (OAR).
|
||||||
|
*
|
||||||
|
* The license and distribution terms for this file may be
|
||||||
|
* found in the file LICENSE in this distribution or at
|
||||||
|
* http://www.rtems.com/license/LICENSE.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <rtems/bspcmdline.h>
|
||||||
|
|
||||||
|
extern const char *bsp_boot_cmdline;
|
||||||
|
|
||||||
|
const char *bsp_cmdline_get(void)
|
||||||
|
{
|
||||||
|
return bsp_boot_cmdline;
|
||||||
|
}
|
||||||
67
cpukit/libmisc/bspcmdline/bspcmdline_getparam.c
Normal file
67
cpukit/libmisc/bspcmdline/bspcmdline_getparam.c
Normal file
@@ -0,0 +1,67 @@
|
|||||||
|
/*
|
||||||
|
* COPYRIGHT (c) 1989-2009.
|
||||||
|
* On-Line Applications Research Corporation (OAR).
|
||||||
|
*
|
||||||
|
* The license and distribution terms for this file may be
|
||||||
|
* found in the file LICENSE in this distribution or at
|
||||||
|
* http://www.rtems.com/license/LICENSE.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <rtems/bspcmdline.h>
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
static void copy_string(
|
||||||
|
const char *start,
|
||||||
|
char *value,
|
||||||
|
size_t length
|
||||||
|
)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
int quotes;
|
||||||
|
const char *p = start;
|
||||||
|
|
||||||
|
quotes=0;
|
||||||
|
for (i=0 ; *p && i<length-1; ) {
|
||||||
|
if ( *p == '\"' ) {
|
||||||
|
quotes++;
|
||||||
|
} else if ( ((quotes % 2) == 0) && *p == ' ' )
|
||||||
|
break;
|
||||||
|
value[i++] = *p++;
|
||||||
|
value[i] = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *bsp_cmdline_get_param(
|
||||||
|
const char *name,
|
||||||
|
char *value,
|
||||||
|
size_t length
|
||||||
|
)
|
||||||
|
{
|
||||||
|
const char *p;
|
||||||
|
|
||||||
|
if ( !name )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if ( !value )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if ( !length )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
value[0] = '\0';
|
||||||
|
|
||||||
|
p = bsp_cmdline_get_param_raw( name );
|
||||||
|
|
||||||
|
if ( !p )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
copy_string( p, value, length );
|
||||||
|
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
33
cpukit/libmisc/bspcmdline/bspcmdline_getparamraw.c
Normal file
33
cpukit/libmisc/bspcmdline/bspcmdline_getparamraw.c
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
/*
|
||||||
|
* COPYRIGHT (c) 1989-2009.
|
||||||
|
* On-Line Applications Research Corporation (OAR).
|
||||||
|
*
|
||||||
|
* The license and distribution terms for this file may be
|
||||||
|
* found in the file LICENSE in this distribution or at
|
||||||
|
* http://www.rtems.com/license/LICENSE.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <rtems/bspcmdline.h>
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
extern const char *bsp_boot_cmdline;
|
||||||
|
|
||||||
|
const char *bsp_cmdline_get_param_raw(
|
||||||
|
const char *name
|
||||||
|
)
|
||||||
|
{
|
||||||
|
const char *p;
|
||||||
|
|
||||||
|
if ( !name )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if ( !bsp_boot_cmdline )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
p = strstr(bsp_boot_cmdline, name);
|
||||||
|
/* printf( "raw: %p (%s)\n", p, p ); */
|
||||||
|
return p;
|
||||||
|
}
|
||||||
42
cpukit/libmisc/bspcmdline/bspcmdline_getparamrhs.c
Normal file
42
cpukit/libmisc/bspcmdline/bspcmdline_getparamrhs.c
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
/*
|
||||||
|
* COPYRIGHT (c) 1989-2009.
|
||||||
|
* On-Line Applications Research Corporation (OAR).
|
||||||
|
*
|
||||||
|
* The license and distribution terms for this file may be
|
||||||
|
* found in the file LICENSE in this distribution or at
|
||||||
|
* http://www.rtems.com/license/LICENSE.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <rtems/bspcmdline.h>
|
||||||
|
|
||||||
|
const char *bsp_cmdline_get_param_rhs(
|
||||||
|
const char *name,
|
||||||
|
char *value,
|
||||||
|
size_t length
|
||||||
|
)
|
||||||
|
{
|
||||||
|
const char *p;
|
||||||
|
const char *rhs;
|
||||||
|
char *d;
|
||||||
|
|
||||||
|
p = bsp_cmdline_get_param( name, value, length );
|
||||||
|
if ( !p )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
rhs = &p[strlen(name)];
|
||||||
|
if ( *rhs != '=' )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
rhs++;
|
||||||
|
if ( *rhs == '\"' )
|
||||||
|
rhs++;
|
||||||
|
for ( d=value ; *rhs ; )
|
||||||
|
*d++ = *rhs++;
|
||||||
|
if ( *(d-1) == '\"' )
|
||||||
|
d--;
|
||||||
|
*d = '\0';
|
||||||
|
|
||||||
|
return value;
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user