getopt.cpp revision 9735c8af814f4e79e0c2e4b63b2a61a30faa67bf
/* $Id$ */
/** @file
* IPRT - Command Line Parsing
*/
/*
* Copyright (C) 2007 Sun Microsystems, Inc.
*
* This file is part of VirtualBox Open Source Edition (OSE), as
* available from http://www.virtualbox.org. This file is free software;
* General Public License (GPL) as published by the Free Software
* Foundation, in version 2 as it comes in the "COPYING" file of the
* VirtualBox OSE distribution. VirtualBox OSE is distributed in the
* hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
*
* The contents of this file may alternatively be used under the terms
* of the Common Development and Distribution License Version 1.0
* (CDDL) only, as it comes in the "COPYING.CDDL" file of the
* VirtualBox OSE distribution, in which case the provisions of the
* CDDL are applicable instead of those of the GPL.
*
* You may elect to license modified versions of this file under the
* terms and conditions of either the GPL or the CDDL or both.
*
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
* Clara, CA 95054 USA or visit http://www.sun.com if you need
* additional information or have any questions.
*/
/*******************************************************************************
* Header Files *
*******************************************************************************/
{
/* validate the options. */
{
}
/** @todo Add an flag for sorting the arguments so that all the options comes
* first. */
return VINF_SUCCESS;
}
/**
* Searches for a long option.
*
* @returns Pointer to a matching option.
* @param pszOption The alleged long option.
* @param paOptions Option array.
* @param cOptions Number of items in the array.
*/
static PCRTGETOPTDEF rtGetOptSearchLong(const char *pszOption, PCRTGETOPTDEF paOptions, size_t cOptions)
{
while (cOptions-- > 0)
{
{
{
/*
* A value is required with the argument. We're trying to be very
* understanding here and will permit any of the following:
* --long:value, --long=value, --long value,
* --long: value, --long= value
*/
return pOpt;
}
return pOpt;
}
pOpt++;
}
return NULL;
}
/**
* Searches for a matching short option.
*
* @returns Pointer to a matching option.
* @param chOption The option char.
* @param paOptions Option array.
* @param cOptions Number of items in the array.
*/
{
while (cOptions-- > 0)
{
return pOpt;
pOpt++;
}
return NULL;
}
{
/*
* Make sure the union is completely cleared out, whatever happens below.
*/
pValueUnion->u64 = 0;
/** @todo Handle '--' (end of options).*/
/** @todo Add a flag to RTGetOptInit for handling the various help options in
* a common way. (-?,-h,-help,--help,++) */
/** @todo Add a flag to RTGetOptInit for handling the standard version options
* in a common way. (-V,--version) */
/*
* The next option.
*/
bool fShort;
int iThis;
const char *pszArgThis;
if (pState->pszNextShort)
{
/*
* We've got short options left over from the previous call.
*/
if (!pOpt)
{
return VERR_GETOPT_UNKNOWN_OPTION;
}
pState->pszNextShort++;
fShort = true;
}
else
{
/*
* Pop off the next argument.
*/
return 0;
/*
* Do a long option search first and the a short option one.
* This way we can make sure single dash long options doesn't
* get mixed up with short ones.
*/
if ( !pOpt
&& pszArgThis[0] == '-'
{
}
else
fShort = false;
}
if (pOpt)
{
{
/*
* Find the argument value.
*
* A value is required with the argument. We're trying to be very
* understanding here and will permit any of the following:
* -svalue, -s:value, -s=value,
* -s value, -s: value, -s= value
* (Ditto for long options.)
*/
const char *pszValue;
if (fShort)
{
{
}
else /* same argument. */
if (pState->pszNextShort)
{
}
}
else
{
{
}
else /* same argument. */
}
/*
* Transform into a option value as requested.
* If decimal conversion fails, we'll check for "0x<xdigit>" and
* try a 16 based conversion. We will not interpret any of the
* generic ints as octals.
*/
switch (pOpt->fFlags & (RTGETOPT_REQ_MASK | RTGETOPT_FLAG_HEX | RTGETOPT_FLAG_OCT | RTGETOPT_FLAG_DEC))
{
case RTGETOPT_REQ_STRING:
break;
case req: \
{ \
&& ( pszValue[0] != '0' \
return VERR_GETOPT_INVALID_ARGUMENT_FORMAT; \
break; \
}
case req: \
{ \
return VERR_GETOPT_INVALID_ARGUMENT_FORMAT; \
break; \
}
default:
return VERR_INTERNAL_ERROR;
}
}
else if (fShort)
{
/*
* Deal with "compressed" short option lists, correcting the next
* state variables for the start and end cases.
*/
if (pszArgThis[2])
{
if (!pState->pszNextShort)
{
/* start */
}
}
else if (pState->pszNextShort)
{
/* end */
}
}
}
/*
* Not a known option argument. If it starts with a switch char (-) we'll
* fail with unkown option, and if it doesn't we'll return it as a non-option.
*/
if (*pszArgThis == '-')
{
return VERR_GETOPT_UNKNOWN_OPTION;
}
return VINF_GETOPT_NOT_OPTION;
}