#include <sys/types.h>
#include <limits.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
extern FILE * option_usage_fp;
#define OPTION_CODE_COMPILE 1
#include "ntp-keygen-opts.h"
#ifdef __cplusplus
extern "C" {
#endif
tSCC zCopyright[] =
"ntp-keygen copyright (c) 1970-2009 David L. Mills and/or others, all rights reserved"
;
tSCC zCopyrightNotice[24] =
"see html/copyright.html";
extern tUsageProc optionUsage;
#include <stdlib.h>
#ifdef __windows
extern int atoi(const char*);
#else
# include <stdlib.h>
#endif
#ifndef NULL
# define NULL 0
#endif
#ifndef EXIT_SUCCESS
# define EXIT_SUCCESS 0
#endif
#ifndef EXIT_FAILURE
# define EXIT_FAILURE 1
#endif
#ifdef OPENSSL
tSCC zCertificateText[] =
"certificate scheme";
tSCC zCertificate_NAME[] = "CERTIFICATE";
tSCC zCertificate_Name[] = "certificate";
#define CERTIFICATE_FLAGS (OPTST_DISABLED \
| OPTST_SET_ARGTYPE(OPARG_TYPE_STRING))
#else
#define CERTIFICATE_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zCertificate_NAME NULL
#define zCertificateText NULL
#define zCertificate_Name NULL
#endif
tSCC zDebug_LevelText[] =
"Increase output debug message level";
tSCC zDebug_Level_NAME[] = "DEBUG_LEVEL";
tSCC zDebug_Level_Name[] = "debug-level";
#define DEBUG_LEVEL_FLAGS (OPTST_DISABLED)
tSCC zSet_Debug_LevelText[] =
"Set the output debug message level";
tSCC zSet_Debug_Level_NAME[] = "SET_DEBUG_LEVEL";
tSCC zSet_Debug_Level_Name[] = "set-debug-level";
#define SET_DEBUG_LEVEL_FLAGS (OPTST_DISABLED \
| OPTST_SET_ARGTYPE(OPARG_TYPE_STRING))
#ifdef OPENSSL
tSCC zId_KeyText[] =
"Write IFF or GQ identity keys";
tSCC zId_Key_NAME[] = "ID_KEY";
tSCC zId_Key_Name[] = "id-key";
#define ID_KEY_FLAGS (OPTST_DISABLED)
#else
#define ID_KEY_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zId_Key_NAME NULL
#define zId_KeyText NULL
#define zId_Key_Name NULL
#endif
#ifdef OPENSSL
tSCC zGq_ParamsText[] =
"Generate GQ parameters and keys";
tSCC zGq_Params_NAME[] = "GQ_PARAMS";
tSCC zGq_Params_Name[] = "gq-params";
#define GQ_PARAMS_FLAGS (OPTST_DISABLED)
#else
#define GQ_PARAMS_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zGq_Params_NAME NULL
#define zGq_ParamsText NULL
#define zGq_Params_Name NULL
#endif
#ifdef OPENSSL
tSCC zHost_KeyText[] =
"generate RSA host key";
tSCC zHost_Key_NAME[] = "HOST_KEY";
tSCC zHost_Key_Name[] = "host-key";
#define HOST_KEY_FLAGS (OPTST_DISABLED)
#else
#define HOST_KEY_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zHost_Key_NAME NULL
#define zHost_KeyText NULL
#define zHost_Key_Name NULL
#endif
#ifdef OPENSSL
tSCC zIffkeyText[] =
"generate IFF parameters";
tSCC zIffkey_NAME[] = "IFFKEY";
tSCC zIffkey_Name[] = "iffkey";
#define IFFKEY_FLAGS (OPTST_DISABLED)
#else
#define IFFKEY_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zIffkey_NAME NULL
#define zIffkeyText NULL
#define zIffkey_Name NULL
#endif
#ifdef OPENSSL
tSCC zIssuer_NameText[] =
"set issuer name";
tSCC zIssuer_Name_NAME[] = "ISSUER_NAME";
tSCC zIssuer_Name_Name[] = "issuer-name";
#define ISSUER_NAME_FLAGS (OPTST_DISABLED \
| OPTST_SET_ARGTYPE(OPARG_TYPE_STRING))
#else
#define ISSUER_NAME_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zIssuer_Name_NAME NULL
#define zIssuer_NameText NULL
#define zIssuer_Name_Name NULL
#endif
tSCC zMd5keyText[] =
"generate MD5 keys";
tSCC zMd5key_NAME[] = "MD5KEY";
tSCC zMd5key_Name[] = "md5key";
#define MD5KEY_FLAGS (OPTST_DISABLED)
#ifdef OPENSSL
tSCC zModulusText[] =
"modulus";
tSCC zModulus_NAME[] = "MODULUS";
tSCC zModulus_Name[] = "modulus";
#define MODULUS_FLAGS (OPTST_DISABLED \
| OPTST_SET_ARGTYPE(OPARG_TYPE_NUMERIC))
#else
#define MODULUS_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zModulus_NAME NULL
#define zModulusText NULL
#define zModulus_Name NULL
#endif
#ifdef OPENSSL
tSCC zPvt_CertText[] =
"generate PC private certificate";
tSCC zPvt_Cert_NAME[] = "PVT_CERT";
tSCC zPvt_Cert_Name[] = "pvt-cert";
#define PVT_CERT_FLAGS (OPTST_DISABLED)
#else
#define PVT_CERT_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zPvt_Cert_NAME NULL
#define zPvt_CertText NULL
#define zPvt_Cert_Name NULL
#endif
#ifdef OPENSSL
tSCC zPvt_PasswdText[] =
"output private password";
tSCC zPvt_Passwd_NAME[] = "PVT_PASSWD";
tSCC zPvt_Passwd_Name[] = "pvt-passwd";
#define PVT_PASSWD_FLAGS (OPTST_DISABLED \
| OPTST_SET_ARGTYPE(OPARG_TYPE_STRING))
#else
#define PVT_PASSWD_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zPvt_Passwd_NAME NULL
#define zPvt_PasswdText NULL
#define zPvt_Passwd_Name NULL
#endif
#ifdef OPENSSL
tSCC zGet_Pvt_PasswdText[] =
"input private password";
tSCC zGet_Pvt_Passwd_NAME[] = "GET_PVT_PASSWD";
tSCC zGet_Pvt_Passwd_Name[] = "get-pvt-passwd";
#define GET_PVT_PASSWD_FLAGS (OPTST_DISABLED \
| OPTST_SET_ARGTYPE(OPARG_TYPE_STRING))
#else
#define GET_PVT_PASSWD_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zGet_Pvt_Passwd_NAME NULL
#define zGet_Pvt_PasswdText NULL
#define zGet_Pvt_Passwd_Name NULL
#endif
#ifdef OPENSSL
tSCC zSign_KeyText[] =
"generate sign key (RSA or DSA)";
tSCC zSign_Key_NAME[] = "SIGN_KEY";
tSCC zSign_Key_Name[] = "sign-key";
#define SIGN_KEY_FLAGS (OPTST_DISABLED \
| OPTST_SET_ARGTYPE(OPARG_TYPE_STRING))
#else
#define SIGN_KEY_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zSign_Key_NAME NULL
#define zSign_KeyText NULL
#define zSign_Key_Name NULL
#endif
#ifdef OPENSSL
tSCC zSubject_NameText[] =
"set subject name";
tSCC zSubject_Name_NAME[] = "SUBJECT_NAME";
tSCC zSubject_Name_Name[] = "subject-name";
#define SUBJECT_NAME_FLAGS (OPTST_DISABLED \
| OPTST_SET_ARGTYPE(OPARG_TYPE_STRING))
#else
#define SUBJECT_NAME_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zSubject_Name_NAME NULL
#define zSubject_NameText NULL
#define zSubject_Name_Name NULL
#endif
#ifdef OPENSSL
tSCC zTrusted_CertText[] =
"trusted certificate (TC scheme)";
tSCC zTrusted_Cert_NAME[] = "TRUSTED_CERT";
tSCC zTrusted_Cert_Name[] = "trusted-cert";
#define TRUSTED_CERT_FLAGS (OPTST_DISABLED)
#else
#define TRUSTED_CERT_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zTrusted_Cert_NAME NULL
#define zTrusted_CertText NULL
#define zTrusted_Cert_Name NULL
#endif
#ifdef OPENSSL
tSCC zMv_ParamsText[] =
"generate <num> MV parameters";
tSCC zMv_Params_NAME[] = "MV_PARAMS";
tSCC zMv_Params_Name[] = "mv-params";
#define MV_PARAMS_FLAGS (OPTST_DISABLED \
| OPTST_SET_ARGTYPE(OPARG_TYPE_NUMERIC))
#else
#define MV_PARAMS_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zMv_Params_NAME NULL
#define zMv_ParamsText NULL
#define zMv_Params_Name NULL
#endif
#ifdef OPENSSL
tSCC zMv_KeysText[] =
"update <num> MV keys";
tSCC zMv_Keys_NAME[] = "MV_KEYS";
tSCC zMv_Keys_Name[] = "mv-keys";
#define MV_KEYS_FLAGS (OPTST_DISABLED \
| OPTST_SET_ARGTYPE(OPARG_TYPE_NUMERIC))
#else
#define MV_KEYS_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zMv_Keys_NAME NULL
#define zMv_KeysText NULL
#define zMv_Keys_Name NULL
#endif
tSCC zHelpText[] = "Display extended usage information and exit";
tSCC zHelp_Name[] = "help";
#ifdef HAVE_WORKING_FORK
#define OPTST_MORE_HELP_FLAGS (OPTST_IMM | OPTST_NO_INIT)
tSCC zMore_Help_Name[] = "more-help";
tSCC zMore_HelpText[] = "Extended usage information passed thru pager";
#else
#define OPTST_MORE_HELP_FLAGS (OPTST_OMITTED | OPTST_NO_INIT)
#define zMore_Help_Name NULL
#define zMore_HelpText NULL
#endif
#ifdef NO_OPTIONAL_OPT_ARGS
# define OPTST_VERSION_FLAGS OPTST_IMM | OPTST_NO_INIT
#else
# define OPTST_VERSION_FLAGS OPTST_SET_ARGTYPE(OPARG_TYPE_STRING) | \
OPTST_ARG_OPTIONAL | OPTST_IMM | OPTST_NO_INIT
#endif
tSCC zVersionText[] = "Output version information and exit";
tSCC zVersion_Name[] = "version";
tSCC zSave_OptsText[] = "Save the option state to a config file";
tSCC zSave_Opts_Name[] = "save-opts";
tSCC zLoad_OptsText[] = "Load options from a config file";
tSCC zLoad_Opts_NAME[] = "LOAD_OPTS";
tSCC zNotLoad_Opts_Name[] = "no-load-opts";
tSCC zNotLoad_Opts_Pfx[] = "no";
#define zLoad_Opts_Name (zNotLoad_Opts_Name + 3)
#ifdef OPENSSL
static tOptProc doOptModulus;
#else
# define doOptModulus NULL
#endif
#ifdef OPENSSL
extern tOptProc optionNumericVal;
#else
# define optionNumericVal NULL
#endif
#ifdef OPENSSL
extern tOptProc optionNumericVal;
#else
# define optionNumericVal NULL
#endif
#if defined(TEST_NTP_KEYGEN_OPTS)
extern tOptProc
optionNumericVal, optionPagedUsage, optionVersionStderr;
static tOptProc
doOptModulus, doUsageOpt;
#define SET_DEBUG_LEVEL_OPT_PROC optionStackArg
#else
extern tOptProc
optionPagedUsage, optionPrintVersion;
static tOptProc
doOptSet_Debug_Level, doUsageOpt;
#define SET_DEBUG_LEVEL_OPT_PROC doOptSet_Debug_Level
#define SET_DEBUG_LEVEL_OPT_PROC doOptSet_Debug_Level
#endif
#ifdef TEST_NTP_KEYGEN_OPTS
# define DOVERPROC optionVersionStderr
#else
# define DOVERPROC optionPrintVersion
#endif
static tOptDesc optDesc[ OPTION_CT ] = {
{ 0, VALUE_OPT_CERTIFICATE,
0, VALUE_OPT_CERTIFICATE,
NO_EQUIVALENT,
0, 1, 0,
CERTIFICATE_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zCertificateText, zCertificate_NAME, zCertificate_Name,
NULL, NULL },
{ 1, VALUE_OPT_DEBUG_LEVEL,
1, VALUE_OPT_DEBUG_LEVEL,
NO_EQUIVALENT,
0, NOLIMIT, 0,
DEBUG_LEVEL_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zDebug_LevelText, zDebug_Level_NAME, zDebug_Level_Name,
NULL, NULL },
{ 2, VALUE_OPT_SET_DEBUG_LEVEL,
2, VALUE_OPT_SET_DEBUG_LEVEL,
NO_EQUIVALENT,
0, NOLIMIT, 0,
SET_DEBUG_LEVEL_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
SET_DEBUG_LEVEL_OPT_PROC,
zSet_Debug_LevelText, zSet_Debug_Level_NAME, zSet_Debug_Level_Name,
NULL, NULL },
{ 3, VALUE_OPT_ID_KEY,
3, VALUE_OPT_ID_KEY,
NO_EQUIVALENT,
0, 1, 0,
ID_KEY_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zId_KeyText, zId_Key_NAME, zId_Key_Name,
NULL, NULL },
{ 4, VALUE_OPT_GQ_PARAMS,
4, VALUE_OPT_GQ_PARAMS,
NO_EQUIVALENT,
0, 1, 0,
GQ_PARAMS_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zGq_ParamsText, zGq_Params_NAME, zGq_Params_Name,
NULL, NULL },
{ 5, VALUE_OPT_HOST_KEY,
5, VALUE_OPT_HOST_KEY,
NO_EQUIVALENT,
0, 1, 0,
HOST_KEY_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zHost_KeyText, zHost_Key_NAME, zHost_Key_Name,
NULL, NULL },
{ 6, VALUE_OPT_IFFKEY,
6, VALUE_OPT_IFFKEY,
NO_EQUIVALENT,
0, 1, 0,
IFFKEY_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zIffkeyText, zIffkey_NAME, zIffkey_Name,
NULL, NULL },
{ 7, VALUE_OPT_ISSUER_NAME,
7, VALUE_OPT_ISSUER_NAME,
NO_EQUIVALENT,
0, 1, 0,
ISSUER_NAME_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zIssuer_NameText, zIssuer_Name_NAME, zIssuer_Name_Name,
NULL, NULL },
{ 8, VALUE_OPT_MD5KEY,
8, VALUE_OPT_MD5KEY,
NO_EQUIVALENT,
0, 1, 0,
MD5KEY_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zMd5keyText, zMd5key_NAME, zMd5key_Name,
NULL, NULL },
{ 9, VALUE_OPT_MODULUS,
9, VALUE_OPT_MODULUS,
NO_EQUIVALENT,
0, 1, 0,
MODULUS_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
doOptModulus,
zModulusText, zModulus_NAME, zModulus_Name,
NULL, NULL },
{ 10, VALUE_OPT_PVT_CERT,
10, VALUE_OPT_PVT_CERT,
NO_EQUIVALENT,
0, 1, 0,
PVT_CERT_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zPvt_CertText, zPvt_Cert_NAME, zPvt_Cert_Name,
NULL, NULL },
{ 11, VALUE_OPT_PVT_PASSWD,
11, VALUE_OPT_PVT_PASSWD,
NO_EQUIVALENT,
0, 1, 0,
PVT_PASSWD_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zPvt_PasswdText, zPvt_Passwd_NAME, zPvt_Passwd_Name,
NULL, NULL },
{ 12, VALUE_OPT_GET_PVT_PASSWD,
12, VALUE_OPT_GET_PVT_PASSWD,
NO_EQUIVALENT,
0, 1, 0,
GET_PVT_PASSWD_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zGet_Pvt_PasswdText, zGet_Pvt_Passwd_NAME, zGet_Pvt_Passwd_Name,
NULL, NULL },
{ 13, VALUE_OPT_SIGN_KEY,
13, VALUE_OPT_SIGN_KEY,
NO_EQUIVALENT,
0, 1, 0,
SIGN_KEY_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zSign_KeyText, zSign_Key_NAME, zSign_Key_Name,
NULL, NULL },
{ 14, VALUE_OPT_SUBJECT_NAME,
14, VALUE_OPT_SUBJECT_NAME,
NO_EQUIVALENT,
0, 1, 0,
SUBJECT_NAME_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zSubject_NameText, zSubject_Name_NAME, zSubject_Name_Name,
NULL, NULL },
{ 15, VALUE_OPT_TRUSTED_CERT,
15, VALUE_OPT_TRUSTED_CERT,
NO_EQUIVALENT,
0, 1, 0,
TRUSTED_CERT_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zTrusted_CertText, zTrusted_Cert_NAME, zTrusted_Cert_Name,
NULL, NULL },
{ 16, VALUE_OPT_MV_PARAMS,
16, VALUE_OPT_MV_PARAMS,
NO_EQUIVALENT,
0, 1, 0,
MV_PARAMS_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
optionNumericVal,
zMv_ParamsText, zMv_Params_NAME, zMv_Params_Name,
NULL, NULL },
{ 17, VALUE_OPT_MV_KEYS,
17, VALUE_OPT_MV_KEYS,
NO_EQUIVALENT,
0, 1, 0,
MV_KEYS_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
optionNumericVal,
zMv_KeysText, zMv_Keys_NAME, zMv_Keys_Name,
NULL, NULL },
{ INDEX_OPT_VERSION, VALUE_OPT_VERSION,
NO_EQUIVALENT, 0,
NO_EQUIVALENT,
0, 1, 0,
OPTST_VERSION_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
DOVERPROC,
zVersionText, NULL, zVersion_Name,
NULL, NULL },
{ INDEX_OPT_HELP, VALUE_OPT_HELP,
NO_EQUIVALENT, 0,
NO_EQUIVALENT,
0, 1, 0,
OPTST_IMM | OPTST_NO_INIT, 0,
{ NULL },
NULL,
NULL, NULL,
doUsageOpt,
zHelpText, NULL, zHelp_Name,
NULL, NULL },
{ INDEX_OPT_MORE_HELP, VALUE_OPT_MORE_HELP,
NO_EQUIVALENT, 0,
NO_EQUIVALENT,
0, 1, 0,
OPTST_MORE_HELP_FLAGS, 0,
{ NULL },
NULL,
NULL, NULL,
optionPagedUsage,
zMore_HelpText, NULL, zMore_Help_Name,
NULL, NULL },
{ INDEX_OPT_SAVE_OPTS, VALUE_OPT_SAVE_OPTS,
NO_EQUIVALENT, 0,
NO_EQUIVALENT,
0, 1, 0,
OPTST_SET_ARGTYPE(OPARG_TYPE_STRING)
| OPTST_ARG_OPTIONAL | OPTST_NO_INIT, 0,
{ NULL },
NULL,
NULL, NULL,
NULL,
zSave_OptsText, NULL, zSave_Opts_Name,
NULL, NULL },
{ INDEX_OPT_LOAD_OPTS, VALUE_OPT_LOAD_OPTS,
NO_EQUIVALENT, 0,
NO_EQUIVALENT,
0, NOLIMIT, 0,
OPTST_SET_ARGTYPE(OPARG_TYPE_STRING)
| OPTST_DISABLE_IMM, 0,
{ NULL },
NULL,
NULL, NULL,
optionLoadOpt,
zLoad_OptsText, zLoad_Opts_NAME, zLoad_Opts_Name,
zNotLoad_Opts_Name, zNotLoad_Opts_Pfx }
};
tSCC zPROGNAME[] = "NTP_KEYGEN";
tSCC zUsageTitle[] =
"ntp-keygen (ntp) - Create a NTP host key - Ver. 4.2.6\n\
USAGE: %s [ -<flag> [<val>] | --<name>[{=| }<val>] ]...\n";
tSCC zRcName[] = ".ntprc";
tSCC* apzHomeList[] = {
"$HOME",
".",
NULL };
tSCC zBugsAddr[] = "http://bugs.ntp.org, bugs@ntp.org";
#define zExplain NULL
tSCC zDetail[] = "\n\
If there is no new host key, look for an existing one.\n\
If one is not found, create it.\n";
tSCC zFullVersion[] = NTP_KEYGEN_FULL_VERSION;
#if defined(ENABLE_NLS)
# define OPTPROC_BASE OPTPROC_TRANSLATE
static tOptionXlateProc translate_option_strings;
#else
# define OPTPROC_BASE OPTPROC_NONE
# define translate_option_strings NULL
#endif
#define ntp_keygen_full_usage NULL
#define ntp_keygen_short_usage NULL
tOptions ntp_keygenOptions = {
OPTIONS_STRUCT_VERSION,
0, NULL,
( OPTPROC_BASE
+ OPTPROC_ERRSTOP
+ OPTPROC_SHORTOPT
+ OPTPROC_LONGOPT
+ OPTPROC_NO_REQ_OPT
+ OPTPROC_ENVIRON
+ OPTPROC_NO_ARGS ),
0, NULL,
NULL, NULL, zPROGNAME,
zRcName, zCopyright, zCopyrightNotice,
zFullVersion, apzHomeList, zUsageTitle,
zExplain, zDetail, optDesc,
zBugsAddr,
NULL, NULL,
optionUsage,
translate_option_strings,
{ INDEX_OPT_MORE_HELP,
INDEX_OPT_SAVE_OPTS,
NO_EQUIVALENT,
NO_EQUIVALENT
},
23 , 18 ,
ntp_keygen_full_usage, ntp_keygen_short_usage,
NULL, NULL
};
static void
doUsageOpt(
tOptions* pOptions,
tOptDesc* pOptDesc )
{
(void)pOptions;
USAGE( EXIT_SUCCESS );
}
#if ! defined(TEST_NTP_KEYGEN_OPTS)
static void
doOptSet_Debug_Level(tOptions* pOptions, tOptDesc* pOptDesc)
{
DESC(DEBUG_LEVEL).optOccCt = atoi( pOptDesc->pzLastArg );
}
#endif
#ifdef OPENSSL
static void
doOptModulus(tOptions* pOptions, tOptDesc* pOptDesc)
{
static const struct {long const rmin, rmax;} rng[1] = {
{ 256, 2048 } };
long val;
int ix;
char * pzEnd;
if (pOptions <= OPTPROC_EMIT_LIMIT)
goto emit_ranges;
errno = 0;
val = strtol(pOptDesc->optArg.argString, &pzEnd, 0);
if ((pOptDesc->optArg.argString == pzEnd) || (errno != 0))
goto bad_value;
if (*pzEnd != '\0')
goto bad_value;
for (ix = 0; ix < 1; ix++) {
if (val < rng[ix].rmin)
continue;
if (val == rng[ix].rmin)
goto valid_return;
if (rng[ix].rmax == LONG_MIN)
continue;
if (val <= rng[ix].rmax)
goto valid_return;
}
bad_value:
option_usage_fp = stderr;
emit_ranges:
optionShowRange(pOptions, pOptDesc, (void *)rng, 1);
return;
valid_return:
if ((pOptDesc->fOptState & OPTST_ALLOC_ARG) != 0) {
free((void *)pOptDesc->optArg.argString);
pOptDesc->fOptState &= ~OPTST_ALLOC_ARG;
}
pOptDesc->optArg.argInt = val;
}
#endif
#if defined(TEST_NTP_KEYGEN_OPTS)
extern void optionPutShell( tOptions* );
int
main(int argc, char** argv)
{
int res = EXIT_SUCCESS;
(void)optionProcess( &ntp_keygenOptions, argc, argv );
optionPutShell( &ntp_keygenOptions );
return res;
}
#endif
#if ENABLE_NLS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <autoopts/usage-txt.h>
static char* AO_gettext( char const* pz );
static void coerce_it(void** s);
static char*
AO_gettext( char const* pz )
{
char* pzRes;
if (pz == NULL)
return NULL;
pzRes = _(pz);
if (pzRes == pz)
return pzRes;
pzRes = strdup( pzRes );
if (pzRes == NULL) {
fputs( _("No memory for duping translated strings\n"), stderr );
exit( EXIT_FAILURE );
}
return pzRes;
}
static void coerce_it(void** s) { *s = AO_gettext(*s); }
#define COERSION(_f) \
coerce_it((void*)&(ntp_keygenOptions._f))
static void
translate_option_strings( void )
{
if (option_usage_text.field_ct != 0) {
tOptDesc* pOD = ntp_keygenOptions.pOptDesc;
char** ppz = (char**)(void*)&(option_usage_text);
int ix = option_usage_text.field_ct;
do {
ppz++;
*ppz = AO_gettext(*ppz);
} while (--ix > 0);
COERSION(pzCopyright);
COERSION(pzCopyNotice);
COERSION(pzFullVersion);
COERSION(pzUsageTitle);
COERSION(pzExplain);
COERSION(pzDetail);
option_usage_text.field_ct = 0;
for (ix = ntp_keygenOptions.optCt; ix > 0; ix--, pOD++)
coerce_it((void*)&(pOD->pzText));
}
if ((ntp_keygenOptions.fOptSet & OPTPROC_NXLAT_OPT_CFG) == 0) {
tOptDesc* pOD = ntp_keygenOptions.pOptDesc;
int ix;
for (ix = ntp_keygenOptions.optCt; ix > 0; ix--, pOD++) {
coerce_it((void*)&(pOD->pz_Name));
coerce_it((void*)&(pOD->pz_DisableName));
coerce_it((void*)&(pOD->pz_DisablePfx));
}
ntp_keygenOptions.fOptSet |= OPTPROC_NXLAT_OPT_CFG | OPTPROC_NXLAT_OPT;
}
}
#endif
#ifdef __cplusplus
}
#endif