Subversion Repositories Kolibri OS

Rev

Blame | Last modification | View Log | Download | RSS feed

  1. /****************************************************************************
  2. *
  3. *                            Open Watcom Project
  4. *
  5. *    Portions Copyright (c) 1983-2002 Sybase, Inc. All Rights Reserved.
  6. *
  7. *  ========================================================================
  8. *
  9. *    This file contains Original Code and/or Modifications of Original
  10. *    Code as defined in and that are subject to the Sybase Open Watcom
  11. *    Public License version 1.0 (the 'License'). You may not use this file
  12. *    except in compliance with the License. BY USING THIS FILE YOU AGREE TO
  13. *    ALL TERMS AND CONDITIONS OF THE LICENSE. A copy of the License is
  14. *    provided with the Original Code and Modifications, and is also
  15. *    available at www.sybase.com/developer/opensource.
  16. *
  17. *    The Original Code and all software distributed under the License are
  18. *    distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
  19. *    EXPRESS OR IMPLIED, AND SYBASE AND ALL CONTRIBUTORS HEREBY DISCLAIM
  20. *    ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF
  21. *    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR
  22. *    NON-INFRINGEMENT. Please see the License for the specific language
  23. *    governing rights and limitations under the License.
  24. *
  25. *  ========================================================================
  26. *
  27. * Description:  Implementation of sscanf_s() - safe formatted string input.
  28. *
  29. ****************************************************************************/
  30.  
  31.  
  32. #include "variety.h"
  33. #include "saferlib.h"
  34. #include "widechar.h"
  35. #include <stdio.h>
  36. #include <stdarg.h>
  37. #include <wchar.h>
  38. #include "scanf.h"
  39.  
  40.  
  41. static int cget_string( PTR_SCNF_SPECS specs )
  42. {
  43.     int     c;
  44.  
  45.     if( (c = *(specs->ptr)) != NULLCHAR ) {
  46.         ++(specs->ptr);
  47.     } else {
  48.         c = EOF;
  49.         specs->eoinp = 1;
  50.     }
  51.     return( c );
  52. }
  53.  
  54.  
  55. static void uncget_string( int c, PTR_SCNF_SPECS specs )
  56. {
  57.     --specs->ptr;
  58. }
  59.  
  60.  
  61.  
  62. _WCRTLINK int __F_NAME(sscanf_s,swscanf_s)( const CHAR_TYPE *s, const CHAR_TYPE *format, ... )
  63. {
  64.     SCNF_SPECS      specs;
  65.     const char      *msg;
  66.     int             rc;
  67.     va_list         args;
  68.  
  69.     /* Basic check for null pointers to see if we can continue */
  70.     if( __check_constraint_nullptr_msg( msg, s )
  71.      && __check_constraint_nullptr_msg( msg, format ) ) {
  72.  
  73.         specs.ptr        = (CHAR_TYPE *)s;
  74.         specs.cget_rtn   = cget_string;
  75.         specs.uncget_rtn = uncget_string;
  76.         msg = NULL;
  77.         va_start( args, format );
  78.         rc = __F_NAME(__scnf_s,__wscnf_s)( (PTR_SCNF_SPECS)&specs, format, &msg, args );
  79.         va_end( args );
  80.         if( msg == NULL ) {
  81.             /* no rt-constraint violation inside worker routine */
  82.             return( rc );
  83.         }
  84.     }
  85.     __rtct_fail( __func__, msg, NULL );
  86.     return( __F_NAME(EOF,WEOF) );
  87. }
  88.