int.c
上传用户:blenddy
上传日期:2007-01-07
资源大小:6495k
文件大小:10k
源码类别:

数据库系统

开发平台:

Unix_Linux

  1. /*-------------------------------------------------------------------------
  2.  *
  3.  * int.c
  4.  *   Functions for the built-in integer types.
  5.  *
  6.  * Copyright (c) 1994, Regents of the University of California
  7.  *
  8.  *
  9.  * IDENTIFICATION
  10.  *   $Header: /usr/local/cvsroot/pgsql/src/backend/utils/adt/int.c,v 1.21.2.1 1999/08/02 05:24:53 scrappy Exp $
  11.  *
  12.  *-------------------------------------------------------------------------
  13.  */
  14. /*
  15.  * OLD COMMENTS
  16.  * I/O routines:
  17.  *  int2in, int2out, int28in, int28out, int4in, int4out
  18.  * Conversion routines:
  19.  *  itoi, int2_text, int4_text
  20.  * Boolean operators:
  21.  *  inteq, intne, intlt, intle, intgt, intge
  22.  * Arithmetic operators:
  23.  *  intpl, intmi, int4mul, intdiv
  24.  *
  25.  * Arithmetic operators:
  26.  *  intmod, int4fac
  27.  *
  28.  * XXX makes massive and possibly unwarranted type promotion assumptions.
  29.  * fix me when we figure out what we want to do about ANSIfication...
  30.  */
  31. #include "postgres.h"
  32. #ifdef HAVE_LIMITS_H
  33. #include <limits.h>
  34. #endif
  35. #include "utils/builtins.h"
  36. #ifndef SHRT_MAX
  37. #define SHRT_MAX (0x7FFF)
  38. #endif
  39. #ifndef SHRT_MIN
  40. #define SHRT_MIN (-0x8000)
  41. #endif
  42. /*****************************************************************************
  43.  *  USER I/O ROUTINES  *
  44.  *****************************************************************************/
  45. /*
  46.  * int2in - converts "num" to short
  47.  */
  48. int32
  49. int2in(char *num)
  50. {
  51. return (int32) pg_atoi(num, sizeof(int16), '');
  52. }
  53. /*
  54.  * int2out - converts short to "num"
  55.  */
  56. char *
  57. int2out(int16 sh)
  58. {
  59. char    *result;
  60. result = (char *) palloc(7);/* assumes sign, 5 digits, '' */
  61. itoa((int) sh, result);
  62. return result;
  63. }
  64. /*
  65.  * int28in - converts "num num ..." to internal form
  66.  *
  67.  * Note:
  68.  * Fills any nonexistent digits with NULLs.
  69.  */
  70. int16 *
  71. int28in(char *shs)
  72. {
  73. int16    *result;
  74. int nums;
  75. if (shs == NULL)
  76. return NULL;
  77. result = (int16 *) palloc(sizeof(int16[8]));
  78. if ((nums = sscanf(shs, "%hd%hd%hd%hd%hd%hd%hd%hd",
  79.    &result[0],
  80.    &result[1],
  81.    &result[2],
  82.    &result[3],
  83.    &result[4],
  84.    &result[5],
  85.    &result[6],
  86.    &result[7])) != 8)
  87. {
  88. do
  89. result[nums++] = 0;
  90. while (nums < 8);
  91. }
  92. return result;
  93. }
  94. /*
  95.  * int28out - converts internal form to "num num ..."
  96.  */
  97. char *
  98. int28out(int16 *shs)
  99. {
  100. int num;
  101. int16    *sp;
  102. char    *rp;
  103. char    *result;
  104. if (shs == NULL)
  105. {
  106. result = (char *) palloc(2);
  107. result[0] = '-';
  108. result[1] = '';
  109. return result;
  110. }
  111. rp = result = (char *) palloc(8 * 7); /* assumes sign, 5 digits,
  112.  * ' ' */
  113. sp = shs;
  114. for (num = 8; num != 0; num--)
  115. {
  116. itoa(*sp++, rp);
  117. while (*++rp != '')
  118. ;
  119. *rp++ = ' ';
  120. }
  121. *--rp = '';
  122. return result;
  123. }
  124. /*
  125.  * int44in - converts "num num ..." to internal form
  126.  *
  127.  * Note:
  128.  * Fills any nonexistent digits with NULLs.
  129.  */
  130. int32 *
  131. int44in(char *input_string)
  132. {
  133. int32    *foo = (int32 *) palloc(4 * sizeof(int32));
  134. int i = 0;
  135. i = sscanf(input_string,
  136.    "%d, %d, %d, %d",
  137.    &foo[0],
  138.    &foo[1],
  139.    &foo[2],
  140.    &foo[3]);
  141. while (i < 4)
  142. foo[i++] = 0;
  143. return foo;
  144. }
  145. /*
  146.  * int28out - converts internal form to "num num ..."
  147.  */
  148. char *
  149. int44out(int32 *an_array)
  150. {
  151. int temp = 4;
  152. char    *output_string = NULL;
  153. int i;
  154. if (temp > 0)
  155. {
  156. char    *walk;
  157. output_string = (char *) palloc(16 * temp); /* assume 15 digits +
  158.  * sign */
  159. walk = output_string;
  160. for (i = 0; i < temp; i++)
  161. {
  162. itoa(an_array[i], walk);
  163. while (*++walk != '')
  164. ;
  165. *walk++ = ' ';
  166. }
  167. *--walk = '';
  168. }
  169. return output_string;
  170. }
  171. /*****************************************************************************
  172.  *  PUBLIC ROUTINES  *
  173.  *****************************************************************************/
  174. /*
  175.  * int4in - converts "num" to int4
  176.  */
  177. int32
  178. int4in(char *num)
  179. {
  180. return pg_atoi(num, sizeof(int32), '');
  181. }
  182. /*
  183.  * int4out - converts int4 to "num"
  184.  */
  185. char *
  186. int4out(int32 l)
  187. {
  188. char    *result;
  189. result = (char *) palloc(12); /* assumes sign, 10 digits, '' */
  190. ltoa(l, result);
  191. return result;
  192. }
  193. /*
  194.  * ===================
  195.  * CONVERSION ROUTINES
  196.  * ===================
  197.  */
  198. int32
  199. i2toi4(int16 arg1)
  200. {
  201. return (int32) arg1;
  202. }
  203. int16
  204. i4toi2(int32 arg1)
  205. {
  206. if (arg1 < SHRT_MIN)
  207. elog(ERROR, "i4toi2: '%d' causes int2 underflow", arg1);
  208. if (arg1 > SHRT_MAX)
  209. elog(ERROR, "i4toi2: '%d' causes int2 overflow", arg1);
  210. return (int16) arg1;
  211. }
  212. text *
  213. int2_text(int16 arg1)
  214. {
  215. text    *result;
  216. int len;
  217. char    *str;
  218. str = int2out(arg1);
  219. len = (strlen(str) + VARHDRSZ);
  220. result = palloc(len);
  221. VARSIZE(result) = len;
  222. memmove(VARDATA(result), str, (len - VARHDRSZ));
  223. pfree(str);
  224. return result;
  225. } /* int2_text() */
  226. int16
  227. text_int2(text *string)
  228. {
  229. int16 result;
  230. int len;
  231. char    *str;
  232. len = (VARSIZE(string) - VARHDRSZ);
  233. str = palloc(len + 1);
  234. memmove(str, VARDATA(string), len);
  235. *(str + len) = '';
  236. result = int2in(str);
  237. pfree(str);
  238. return result;
  239. } /* text_int2() */
  240. text *
  241. int4_text(int32 arg1)
  242. {
  243. text    *result;
  244. int len;
  245. char    *str;
  246. str = int4out(arg1);
  247. len = (strlen(str) + VARHDRSZ);
  248. result = palloc(len);
  249. VARSIZE(result) = len;
  250. memmove(VARDATA(result), str, (len - VARHDRSZ));
  251. pfree(str);
  252. return result;
  253. } /* int4_text() */
  254. int32
  255. text_int4(text *string)
  256. {
  257. int32 result;
  258. int len;
  259. char    *str;
  260. len = (VARSIZE(string) - VARHDRSZ);
  261. str = palloc(len + 1);
  262. memmove(str, VARDATA(string), len);
  263. *(str + len) = '';
  264. result = int4in(str);
  265. pfree(str);
  266. return result;
  267. } /* text_int4() */
  268. /*
  269.  * =========================
  270.  * BOOLEAN OPERATOR ROUTINES
  271.  * =========================
  272.  */
  273. /*
  274.  * inteq - returns 1 iff arg1 == arg2
  275.  * intne - returns 1 iff arg1 != arg2
  276.  * intlt - returns 1 iff arg1 < arg2
  277.  * intle - returns 1 iff arg1 <= arg2
  278.  * intgt - returns 1 iff arg1 > arg2
  279.  * intge - returns 1 iff arg1 >= arg2
  280.  */
  281. bool
  282. int4eq(int32 arg1, int32 arg2)
  283. {
  284. return arg1 == arg2;
  285. }
  286. bool
  287. int4ne(int32 arg1, int32 arg2)
  288. {
  289. return arg1 != arg2;
  290. }
  291. bool
  292. int4lt(int32 arg1, int32 arg2)
  293. {
  294. return arg1 < arg2;
  295. }
  296. bool
  297. int4le(int32 arg1, int32 arg2)
  298. {
  299. return arg1 <= arg2;
  300. }
  301. bool
  302. int4gt(int32 arg1, int32 arg2)
  303. {
  304. return arg1 > arg2;
  305. }
  306. bool
  307. int4ge(int32 arg1, int32 arg2)
  308. {
  309. return arg1 >= arg2;
  310. }
  311. bool
  312. int2eq(int16 arg1, int16 arg2)
  313. {
  314. return arg1 == arg2;
  315. }
  316. bool
  317. int2ne(int16 arg1, int16 arg2)
  318. {
  319. return arg1 != arg2;
  320. }
  321. bool
  322. int2lt(int16 arg1, int16 arg2)
  323. {
  324. return arg1 < arg2;
  325. }
  326. bool
  327. int2le(int16 arg1, int16 arg2)
  328. {
  329. return arg1 <= arg2;
  330. }
  331. bool
  332. int2gt(int16 arg1, int16 arg2)
  333. {
  334. return arg1 > arg2;
  335. }
  336. bool
  337. int2ge(int16 arg1, int16 arg2)
  338. {
  339. return arg1 >= arg2;
  340. }
  341. bool
  342. int24eq(int32 arg1, int32 arg2)
  343. {
  344. return arg1 == arg2;
  345. }
  346. bool
  347. int24ne(int32 arg1, int32 arg2)
  348. {
  349. return arg1 != arg2;
  350. }
  351. bool
  352. int24lt(int32 arg1, int32 arg2)
  353. {
  354. return arg1 < arg2;
  355. }
  356. bool
  357. int24le(int32 arg1, int32 arg2)
  358. {
  359. return arg1 <= arg2;
  360. }
  361. bool
  362. int24gt(int32 arg1, int32 arg2)
  363. {
  364. return arg1 > arg2;
  365. }
  366. bool
  367. int24ge(int32 arg1, int32 arg2)
  368. {
  369. return arg1 >= arg2;
  370. }
  371. bool
  372. int42eq(int32 arg1, int32 arg2)
  373. {
  374. return arg1 == arg2;
  375. }
  376. bool
  377. int42ne(int32 arg1, int32 arg2)
  378. {
  379. return arg1 != arg2;
  380. }
  381. bool
  382. int42lt(int32 arg1, int32 arg2)
  383. {
  384. return arg1 < arg2;
  385. }
  386. bool
  387. int42le(int32 arg1, int32 arg2)
  388. {
  389. return arg1 <= arg2;
  390. }
  391. bool
  392. int42gt(int32 arg1, int32 arg2)
  393. {
  394. return arg1 > arg2;
  395. }
  396. bool
  397. int42ge(int32 arg1, int32 arg2)
  398. {
  399. return arg1 >= arg2;
  400. }
  401. bool
  402. keyfirsteq(int16 *arg1, int16 arg2)
  403. {
  404. return *arg1 == arg2;
  405. }
  406. /*
  407.  * int[24]pl - returns arg1 + arg2
  408.  * int[24]mi - returns arg1 - arg2
  409.  * int[24]mul - returns arg1 * arg2
  410.  * int[24]div - returns arg1 / arg2
  411.  */
  412. int32
  413. int4um(int32 arg)
  414. {
  415. return -arg;
  416. }
  417. int32
  418. int4pl(int32 arg1, int32 arg2)
  419. {
  420. return arg1 + arg2;
  421. }
  422. int32
  423. int4mi(int32 arg1, int32 arg2)
  424. {
  425. return arg1 - arg2;
  426. }
  427. int32
  428. int4mul(int32 arg1, int32 arg2)
  429. {
  430. return arg1 * arg2;
  431. }
  432. int32
  433. int4div(int32 arg1, int32 arg2)
  434. {
  435. return arg1 / arg2;
  436. }
  437. int32
  438. int4inc(int32 arg)
  439. {
  440. return arg + (int32) 1;
  441. }
  442. int16
  443. int2um(int16 arg)
  444. {
  445. return -arg;
  446. }
  447. int16
  448. int2pl(int16 arg1, int16 arg2)
  449. {
  450. return arg1 + arg2;
  451. }
  452. int16
  453. int2mi(int16 arg1, int16 arg2)
  454. {
  455. return arg1 - arg2;
  456. }
  457. int16
  458. int2mul(int16 arg1, int16 arg2)
  459. {
  460. return arg1 * arg2;
  461. }
  462. int16
  463. int2div(int16 arg1, int16 arg2)
  464. {
  465. return arg1 / arg2;
  466. }
  467. int16
  468. int2inc(int16 arg)
  469. {
  470. return arg + (int16) 1;
  471. }
  472. int32
  473. int24pl(int32 arg1, int32 arg2)
  474. {
  475. return arg1 + arg2;
  476. }
  477. int32
  478. int24mi(int32 arg1, int32 arg2)
  479. {
  480. return arg1 - arg2;
  481. }
  482. int32
  483. int24mul(int32 arg1, int32 arg2)
  484. {
  485. return arg1 * arg2;
  486. }
  487. int32
  488. int24div(int32 arg1, int32 arg2)
  489. {
  490. return arg1 / arg2;
  491. }
  492. int32
  493. int42pl(int32 arg1, int32 arg2)
  494. {
  495. return arg1 + arg2;
  496. }
  497. int32
  498. int42mi(int32 arg1, int32 arg2)
  499. {
  500. return arg1 - arg2;
  501. }
  502. int32
  503. int42mul(int32 arg1, int32 arg2)
  504. {
  505. return arg1 * arg2;
  506. }
  507. int32
  508. int42div(int32 arg1, int32 arg2)
  509. {
  510. return arg1 / arg2;
  511. }
  512. /*
  513.  * int[24]mod - returns arg1 mod arg2
  514.  */
  515. int32
  516. int4mod(int32 arg1, int32 arg2)
  517. {
  518. return arg1 % arg2;
  519. }
  520. int32
  521. int2mod(int16 arg1, int16 arg2)
  522. {
  523. return arg1 % arg2;
  524. }
  525. int32
  526. int24mod(int32 arg1, int32 arg2)
  527. {
  528. return arg1 % arg2;
  529. }
  530. int32
  531. int42mod(int32 arg1, int32 arg2)
  532. {
  533. return arg1 % arg2;
  534. }
  535. /*
  536.  * int[24]fac - returns arg1!
  537.  */
  538. int32
  539. int4fac(int32 arg1)
  540. {
  541. int32 result;
  542. if (arg1 < 1)
  543. result = 0;
  544. else
  545. for (result = 1; arg1 > 0; --arg1)
  546. result *= arg1;
  547. return result;
  548. }
  549. int32
  550. int2fac(int16 arg1)
  551. {
  552. int16 result;
  553. if (arg1 < 1)
  554. result = 0;
  555. else
  556. for (result = 1; arg1 > 0; --arg1)
  557. result *= arg1;
  558. return result;
  559. }
  560. int16
  561. int2larger(int16 arg1, int16 arg2)
  562. {
  563. return (arg1 > arg2) ? arg1 : arg2;
  564. }
  565. int16
  566. int2smaller(int16 arg1, int16 arg2)
  567. {
  568. return (arg1 < arg2) ? arg1 : arg2;
  569. }
  570. int32
  571. int4larger(int32 arg1, int32 arg2)
  572. {
  573. return (arg1 > arg2) ? arg1 : arg2;
  574. }
  575. int32
  576. int4smaller(int32 arg1, int32 arg2)
  577. {
  578. return (arg1 < arg2) ? arg1 : arg2;
  579. }