rand.c
上传用户:qaz666999
上传日期:2022-08-06
资源大小:2570k
文件大小:2k
源码类别:

数学计算

开发平台:

Unix_Linux

  1. /* gmp_randinit (state, algorithm, ...) -- Initialize a random state.
  2. Copyright 1999, 2000, 2001, 2002 Free Software Foundation, Inc.
  3. This file is part of the GNU MP Library.
  4. The GNU MP Library is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU Lesser General Public License as published by
  6. the Free Software Foundation; either version 3 of the License, or (at your
  7. option) any later version.
  8. The GNU MP Library is distributed in the hope that it will be useful, but
  9. WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
  10. or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
  11. License for more details.
  12. You should have received a copy of the GNU Lesser General Public License
  13. along with the GNU MP Library.  If not, see http://www.gnu.org/licenses/.  */
  14. #include "config.h"
  15. #include <stdio.h> /* for NULL */
  16. #if HAVE_STDARG
  17. #include <stdarg.h>
  18. #else
  19. #include <varargs.h>
  20. #endif
  21. #include "gmp.h"
  22. #include "gmp-impl.h"
  23. void
  24. #if HAVE_STDARG
  25. gmp_randinit (gmp_randstate_t rstate,
  26.       gmp_randalg_t alg,
  27.       ...)
  28. #else
  29. gmp_randinit (va_alist)
  30.      va_dcl
  31. #endif
  32. {
  33.   va_list ap;
  34. #if HAVE_STDARG
  35.   va_start (ap, alg);
  36. #else
  37.   __gmp_randstate_struct *rstate;
  38.   gmp_randalg_t alg;
  39.   va_start (ap);
  40.   rstate = va_arg (ap, __gmp_randstate_struct *);
  41.   alg = va_arg (ap, gmp_randalg_t);
  42. #endif
  43.   switch (alg) {
  44.   case GMP_RAND_ALG_LC:
  45.     if (! gmp_randinit_lc_2exp_size (rstate, va_arg (ap, unsigned long)))
  46.       gmp_errno |= GMP_ERROR_INVALID_ARGUMENT;
  47.     break;
  48.   default:
  49.     gmp_errno |= GMP_ERROR_UNSUPPORTED_ARGUMENT;
  50.     break;
  51.   }
  52.   va_end (ap);
  53. }