• R/O
  • HTTP
  • SSH
  • HTTPS

タグ
未設定

よく使われているワード(クリックで追加)

javac++androidlinuxc#windowsobjective-ccocoa誰得qtpythonphprubygameguibathyscaphec計画中(planning stage)翻訳omegatframeworktwitterdomtestvb.netdirectxゲームエンジンbtronarduinopreviewer

POSIX.1 National Language Support API for MinGW


ファイル情報

Rev. e8a4ca7c72694a37645e1013e561569c8dbb322b
サイズ 2,453 バイト
日時 2008-02-16 21:57:19
作者 Keith Marshall
ログメッセージ

MinGW-catgets version 1.0.1 released.
Source update only: correct make install' defect.

内容

/*
 * mcref.c
 *
 * $Id$
 *
 * Copyright (C) 2006, Keith Marshall
 *
 * This file implements the `_mc_select_' function, which is used to map
 * a message catalogue descriptor, of type `nl_catd', to an actual pointer
 * to the message data, as established by calling the `catopen' function,
 * and recorded in the internal message catalogue descriptor table.
 *
 * Written by Keith Marshall  <keithmarshall@users.sourceforge.net>
 * Last modification: 07-Dec-2006
 *
 *
 * This is free software.  It is provided AS IS, in the hope that it may
 * be useful, but WITHOUT WARRANTY OF ANY KIND, not even an IMPLIED WARRANTY
 * of MERCHANTABILITY, nor of FITNESS FOR ANY PARTICULAR PURPOSE.
 *
 * Permission is granted to redistribute this software, either "as is" or
 * in modified form, 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.
 *
 * You should have received a copy of the GNU General Public License
 * along with this software; see the file COPYING.  If not, write to the
 * Free Software Foundation, 51 Franklin St - Fifth Floor, Boston,
 * MA 02110-1301, USA.
 *
 */

#include <stdarg.h>
#include <stdlib.h>
#include <nl_types.h>

#include <msgcat.h>
#include <mctab.h>

static
void *do_mc_select( struct mc_tab *cdt, va_list argv )
{
  /* This call-back function provides the actual implementation.
   * It receives a pointer to the catalogue descriptor table, and the
   * caller's catalogue descriptor, from the `_mc_select_' function call,
   * redirected via `_mctab_' to get the `cdt' pointer; it verifies that
   * the `cdt' has been initialised, and that the specified descriptor
   * refers to a valid `cdt' entry, then returns the message data
   * pointer stored in that `cdt' entry, or NULL on failure.
   *
   * Note that, although this call-back function returns a pointer of
   * type `MSGCAT *', it is implemented with a generic `void *' return
   * type declaration, for compatibility with `_mctab_'.
   */
  
  nl_catd catd = va_arg( argv, nl_catd );
  return( cdt->tab && (catd >= 0) && (catd < cdt->curr_size) )
    ? cdt->tab[ catd ].data
    : NULL;
}

MSGCAT *_mc_select_( nl_catd catd )
{
  /* The public interface is a trivial call-back request to the preceding
   * function, through the `_mctab_' redirector.
   */

  return (MSGCAT *)_mctab_( do_mc_select, catd );
}

/* $RCSfile$Revision$: end of file */