t-cmp_si.c

来自「a very popular packet of cryptography to」· C语言 代码 · 共 108 行

C
108
字号
/* Test mpf_cmp_si.Copyright 2000, 2001 Free Software Foundation, Inc.This file is part of the GNU MP Library.The GNU MP Library is free software; you can redistribute it and/or modifyit under the terms of the GNU Lesser General Public License as published bythe Free Software Foundation; either version 2.1 of the License, or (at youroption) any later version.The GNU MP Library is distributed in the hope that it will be useful, butWITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITYor FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General PublicLicense for more details.You should have received a copy of the GNU Lesser General Public Licensealong with the GNU MP Library; see the file COPYING.LIB.  If not, write tothe Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,MA 02111-1307, USA. */#include <stdio.h>#include <stdlib.h>#include "gmp.h"#include "gmp-impl.h"#include "tests.h"#define SGN(x)       ((x) < 0 ? -1 : (x) == 0 ? 0 : 1)voidcheck_data (void){  static const struct {    int         a_base;    const char  *a;    const char  *b;    int         want;  } data[] = {    { 10, "0",  "1", -1 },    { 10, "0",  "0",  0 },    { 10, "0", "-1",  1 },    { 10, "1",  "1", 0 },    { 10, "1",  "0", 1 },    { 10, "1", "-1", 1 },    { 10, "-1",  "1", -1 },    { 10, "-1",  "0", -1 },    { 10, "-1", "-1", 0 },    { 16,         "0", "-0x80000000",  1 },    { 16,  "80000000", "-0x80000000",  1 },    { 16,  "80000001", "-0x80000000",  1 },    { 16, "-80000000", "-0x80000000",  0 },    { 16, "-80000001", "-0x80000000", -1 },    { 16,                 "0", "-0x8000000000000000",  1 },    { 16,  "8000000000000000", "-0x8000000000000000",  1 },    { 16,  "8000000000000001", "-0x8000000000000000",  1 },    { 16, "-8000000000000000", "-0x8000000000000000",  0 },    { 16, "-8000000000000001", "-0x8000000000000000", -1 },  };  mpf_t  a;  mpz_t  bz;  long   b;  int    got;  int    i;  mpf_init (a);  mpz_init (bz);  for (i = 0; i < numberof (data); i++)    {      mpf_set_str_or_abort (a, data[i].a, data[i].a_base);      mpz_set_str_or_abort (bz, data[i].b, 0);      if (mpz_fits_slong_p (bz))        {          b = mpz_get_si (bz);          got = mpf_cmp_si (a, b);          if (SGN (got) != data[i].want)            {              printf ("mpf_cmp_si wrong on data[%d]\n", i);              printf ("  a="); mpf_out_str (stdout, 10, 0, a);              printf (" (%s)\n", data[i].a);              printf ("  b=%ld (%s)\n", b, data[i].b);              printf ("  got=%d\n", got);              printf ("  want=%d\n", data[i].want);              abort();                                                }        }    }  mpf_clear (a);  mpz_clear (bz);}intmain (void){  tests_start ();  check_data ();  tests_end ();  exit (0);}

⌨️ 快捷键说明

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