getopt.cpp revision e0b01f0907f9ade6df65e65e86196fa09a11a245
/* $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. */
{
}
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;
}
{
pValueUnion->u64 = 0;
return 0;
/** @todo Handle '--' and possibly implement an RTGetOptInit that lets us
* optionally sort the stuff and set other policeis sorts the result. */
/** @todo Implement short form short option like in:
* ls -latr .
* tar -xzvf foobar.tar.gz
*/
/*
* Pop off the next argument.
*/
/*
* 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.
*/
bool fShort = false;
if ( !pOpt
&& pszArgThis[0] == '-'
{
}
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. */
}
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;
}
}
}
/*
* 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;
}