⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pgusage.c

📁 基于ntp协议的网络时间服务程序
💻 C
字号:
/* *  $Id: pgusage.c,v 4.12 2007/04/28 22:19:23 bkorb Exp $ * Time-stamp:      "2006-07-16 08:13:26 bkorb" * *   Automated Options Paged Usage module. * *  This routine will run run-on options through a pager so the *  user may examine, print or edit them at their leisure. *//* *  Automated Options copyright 1992-2007 Bruce Korb * *  Automated Options is free software. *  You may redistribute it and/or modify it under the terms of the *  GNU General Public License, as published by the Free Software *  Foundation; either version 2, or (at your option) any later version. * *  Automated Options is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with Automated Options.  See the file "COPYING".  If not, *  write to:  The Free Software Foundation, Inc., *             51 Franklin Street, Fifth Floor, *             Boston, MA  02110-1301, USA. * * As a special exception, Bruce Korb gives permission for additional * uses of the text contained in his release of AutoOpts. * * The exception is that, if you link the AutoOpts library with other * files to produce an executable, this does not by itself cause the * resulting executable to be covered by the GNU General Public License. * Your use of that executable is in no way restricted on account of * linking the AutoOpts library code into it. * * This exception does not however invalidate any other reasons why * the executable file might be covered by the GNU General Public License. * * This exception applies only to the code released by Bruce Korb under * the name AutoOpts.  If you copy code from other sources under the * General Public License into a copy of AutoOpts, as the General Public * License permits, the exception does not apply to the code that you add * in this way.  To avoid misleading anyone as to the status of such * modified files, you must delete this exception notice from them. * * If you write modifications of your own for AutoOpts, it is your choice * whether to permit this exception to apply to your modifications. * If you do not wish that, delete this exception notice. */tePagerState pagerState = PAGER_STATE_INITIAL;/*=export_func  optionPagedUsage * private: * * what:  Decipher a boolean value * arg:   + tOptions* + pOpts    + program options descriptor + * arg:   + tOptDesc* + pOptDesc + the descriptor for this arg + * * doc: *  Run the usage output through a pager. *  This is very handy if it is very long.=*/voidoptionPagedUsage( tOptions* pOptions, tOptDesc* pOD ){#if defined(__windows__) && !defined(__CYGWIN__)    (*pOptions->pUsageProc)( pOptions, EXIT_SUCCESS );#else    static pid_t     my_pid;    char zPageUsage[ 1024 ];    /*     *  IF we are being called after the usage proc is done     *     (and thus has called "exit(2)")     *  THEN invoke the pager to page through the usage file we created.     */    switch (pagerState) {    case PAGER_STATE_INITIAL:    {        my_pid  = getpid();#ifdef HAVE_SNPRINTF        snprintf(zPageUsage, sizeof(zPageUsage), "/tmp/use.%lu", (tAoUL)my_pid);#else        sprintf( zPageUsage, "/tmp/use.%lu", (tAoUL)my_pid );#endif        unlink( zPageUsage );        /*         *  Set usage output to this temporary file         */        option_usage_fp = fopen( zPageUsage, "w" FOPEN_BINARY_FLAG );        if (option_usage_fp == NULL)            _exit( EXIT_FAILURE );        pagerState = PAGER_STATE_READY;        /*         *  Set up so this routine gets called during the exit logic         */        atexit( (void(*)(void))optionPagedUsage );        /*         *  The usage procedure will now put the usage information into         *  the temporary file we created above.         */        (*pOptions->pUsageProc)( pOptions, EXIT_SUCCESS );        /*NOTREACHED*/        _exit( EXIT_FAILURE );    }    case PAGER_STATE_READY:    {        tSCC zPage[]  = "%1$s /tmp/use.%2$lu ; rm -f /tmp/use.%2$lu";        tCC* pzPager  = (tCC*)getenv( "PAGER" );        /*         *  Use the "more(1)" program if "PAGER" has not been defined         */        if (pzPager == NULL)            pzPager = "more";        /*         *  Page the file and remove it when done.         */#ifdef HAVE_SNPRINTF        snprintf(zPageUsage, sizeof(zPageUsage), zPage, pzPager, (tAoUL)my_pid);#else        sprintf( zPageUsage, zPage, pzPager, (tAoUL)my_pid );#endif        fclose( stderr );        dup2( STDOUT_FILENO, STDERR_FILENO );        (void)system( zPageUsage );    }    case PAGER_STATE_CHILD:        /*         *  This is a child process used in creating shell script usage.         */        break;    }#endif}/* * Local Variables: * mode: C * c-file-style: "stroustrup" * indent-tabs-mode: nil * End: * end of autoopts/pgusage.c */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -