myisampack.h
上传用户:tsgydb
上传日期:2007-04-14
资源大小:10674k
文件大小:9k
源码类别:

MySQL数据库

开发平台:

Visual C++

  1. /* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
  2.    
  3.    This library is free software; you can redistribute it and/or
  4.    modify it under the terms of the GNU Library General Public
  5.    License as published by the Free Software Foundation; either
  6.    version 2 of the License, or (at your option) any later version.
  7.    
  8.    This library is distributed in the hope that it will be useful,
  9.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  10.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  11.    Library General Public License for more details.
  12.    
  13.    You should have received a copy of the GNU Library General Public
  14.    License along with this library; if not, write to the Free
  15.    Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
  16.    MA 02111-1307, USA */
  17. /*
  18.   Storing of values in high byte first order.
  19.   integer keys and file pointers are stored with high byte first to get
  20.   better compression
  21. */
  22. #define mi_sint2korr(A) (int16) (((int16) ((uchar) (A)[1])) +
  23.  ((int16) ((int16) (A)[0]) << 8))
  24. #define mi_sint3korr(A) ((int32) ((((uchar) (A)[0]) & 128) ? 
  25.   (((uint32) 255L << 24) | 
  26.    (((uint32) (uchar) (A)[0]) << 16) |
  27.    (((uint32) (uchar) (A)[1]) << 8) | 
  28.    ((uint32) (uchar) (A)[2])) : 
  29.   (((uint32) (uchar) (A)[0]) << 16) |
  30.   (((uint32) (uchar) (A)[1]) << 8) | 
  31.   ((uint32) (uchar) (A)[2])))
  32. #define mi_sint4korr(A) (int32) (((int32) ((uchar) (A)[3])) +
  33. (((int32) ((uchar) (A)[2]) << 8)) +
  34. (((int32) ((uchar) (A)[1]) << 16)) +
  35. (((int32) ((int16) (A)[0]) << 24)))
  36. #define mi_sint8korr(A) (longlong) mi_uint8korr(A)
  37. #define mi_uint2korr(A) (uint16) (((uint16) ((uchar) (A)[1])) +
  38.   ((uint16) ((uchar) (A)[0]) << 8))
  39. #define mi_uint3korr(A) (uint32) (((uint32) ((uchar) (A)[2])) +
  40.   (((uint32) ((uchar) (A)[1])) << 8) +
  41.   (((uint32) ((uchar) (A)[0])) << 16))
  42. #define mi_uint4korr(A) (uint32) (((uint32) ((uchar) (A)[3])) +
  43.   (((uint32) ((uchar) (A)[2])) << 8) +
  44.   (((uint32) ((uchar) (A)[1])) << 16) +
  45.   (((uint32) ((uchar) (A)[0])) << 24))
  46. #define mi_uint5korr(A) ((ulonglong)(((uint32) ((uchar) (A)[4])) +
  47.     (((uint32) ((uchar) (A)[3])) << 8) +
  48.     (((uint32) ((uchar) (A)[2])) << 16) +
  49.     (((uint32) ((uchar) (A)[1])) << 24)) +
  50.     (((ulonglong) ((uchar) (A)[0])) << 32))
  51. #define mi_uint6korr(A) ((ulonglong)(((uint32) ((uchar) (A)[5])) +
  52.     (((uint32) ((uchar) (A)[4])) << 8) +
  53.     (((uint32) ((uchar) (A)[3])) << 16) +
  54.     (((uint32) ((uchar) (A)[2])) << 24)) +
  55. (((ulonglong) (((uint32) ((uchar) (A)[1])) +
  56.     (((uint32) ((uchar) (A)[0]) << 8)))) <<
  57.       32))
  58. #define mi_uint7korr(A) ((ulonglong)(((uint32) ((uchar) (A)[6])) +
  59.     (((uint32) ((uchar) (A)[5])) << 8) +
  60.     (((uint32) ((uchar) (A)[4])) << 16) +
  61.     (((uint32) ((uchar) (A)[3])) << 24)) +
  62. (((ulonglong) (((uint32) ((uchar) (A)[2])) +
  63.     (((uint32) ((uchar) (A)[1])) << 8) +
  64.     (((uint32) ((uchar) (A)[0])) << 16))) <<
  65.       32))
  66. #define mi_uint8korr(A) ((ulonglong)(((uint32) ((uchar) (A)[7])) +
  67.     (((uint32) ((uchar) (A)[6])) << 8) +
  68.     (((uint32) ((uchar) (A)[5])) << 16) +
  69.     (((uint32) ((uchar) (A)[4])) << 24)) +
  70. (((ulonglong) (((uint32) ((uchar) (A)[3])) +
  71.     (((uint32) ((uchar) (A)[2])) << 8) +
  72.     (((uint32) ((uchar) (A)[1])) << 16) +
  73.     (((uint32) ((uchar) (A)[0])) << 24))) <<
  74.     32))
  75. #define mi_int2store(T,A)  { uint def_temp= (uint) (A) ;
  76.      *((uchar*) ((T)+1))= (uchar)(def_temp); 
  77.      *((uchar*) ((T)+0))= (uchar)(def_temp >> 8); }
  78. #define mi_int3store(T,A)  { /*lint -save -e734 */
  79.         ulong def_temp= (ulong) (A);
  80.      *(((T)+2))=(char) (def_temp);
  81.       *((T)+1)= (char) (def_temp >> 8);
  82.       *((T)+0)= (char) (def_temp >> 16);
  83.      /*lint -restore */}
  84. #define mi_int4store(T,A)  { ulong def_temp= (ulong) (A);
  85.         *((T)+3)=(char) (def_temp);
  86.      *((T)+2)=(char) (def_temp >> 8);
  87.      *((T)+1)=(char) (def_temp >> 16);
  88.      *((T)+0)=(char) (def_temp >> 24); }
  89. #define mi_int5store(T,A)  { ulong def_temp= (ulong) (A),
  90.      def_temp2= (ulong) ((A) >> 32);
  91.      *((T)+4)=(char) (def_temp);
  92.      *((T)+3)=(char) (def_temp >> 8);
  93.      *((T)+2)=(char) (def_temp >> 16);
  94.      *((T)+1)=(char) (def_temp >> 24);
  95.      *((T)+0)=(char) (def_temp2); }
  96. #define mi_int6store(T,A)  { ulong def_temp= (ulong) (A),
  97.      def_temp2= (ulong) ((A) >> 32);
  98.      *((T)+5)=(char) (def_temp);
  99.      *((T)+4)=(char) (def_temp >> 8);
  100.      *((T)+3)=(char) (def_temp >> 16);
  101.      *((T)+2)=(char) (def_temp >> 24);
  102.      *((T)+1)=(char) (def_temp2);
  103.      *((T)+0)=(char) (def_temp2 >> 8); }
  104. #define mi_int7store(T,A)  { ulong def_temp= (ulong) (A),
  105.      def_temp2= (ulong) ((A) >> 32);
  106.      *((T)+6)=(char) (def_temp);
  107.      *((T)+5)=(char) (def_temp >> 8);
  108.      *((T)+4)=(char) (def_temp >> 16);
  109.      *((T)+3)=(char) (def_temp >> 24);
  110.      *((T)+2)=(char) (def_temp2);
  111.      *((T)+1)=(char) (def_temp2 >> 8);
  112.      *((T)+0)=(char) (def_temp2 >> 16); }
  113. #define mi_int8store(T,A)    { ulong def_temp3= (ulong) (A), 
  114.        def_temp4= (ulong) ((A) >> 32); 
  115.        mi_int4store((T),def_temp4); 
  116.        mi_int4store((T+4),def_temp3); 
  117.      }
  118. #ifdef WORDS_BIGENDIAN
  119. #define mi_float4store(T,A)  { *(T)= ((byte *) &A)[0];
  120.       *((T)+1)=(char) ((byte *) &A)[1];
  121.       *((T)+2)=(char) ((byte *) &A)[2];
  122.       *((T)+3)=(char) ((byte *) &A)[3]; }
  123. #define mi_float4get(V,M)   { float def_temp;
  124.       ((byte*) &def_temp)[0]=(M)[0];
  125.       ((byte*) &def_temp)[1]=(M)[1];
  126.       ((byte*) &def_temp)[2]=(M)[2];
  127.       ((byte*) &def_temp)[3]=(M)[3];
  128.       (V)=def_temp; }
  129. #define mi_float8store(T,V) { *(T)= ((byte *) &V)[0];
  130.       *((T)+1)=(char) ((byte *) &V)[1];
  131.       *((T)+2)=(char) ((byte *) &V)[2];
  132.       *((T)+3)=(char) ((byte *) &V)[3];
  133.       *((T)+4)=(char) ((byte *) &V)[4];
  134.       *((T)+5)=(char) ((byte *) &V)[5];
  135.       *((T)+6)=(char) ((byte *) &V)[6];
  136.       *((T)+7)=(char) ((byte *) &V)[7]; }
  137. #define mi_float8get(V,M)   { double def_temp;
  138.       ((byte*) &def_temp)[0]=(M)[0];
  139.       ((byte*) &def_temp)[1]=(M)[1];
  140.       ((byte*) &def_temp)[2]=(M)[2];
  141.       ((byte*) &def_temp)[3]=(M)[3];
  142.       ((byte*) &def_temp)[4]=(M)[4];
  143.       ((byte*) &def_temp)[5]=(M)[5];
  144.       ((byte*) &def_temp)[6]=(M)[6];
  145.       ((byte*) &def_temp)[7]=(M)[7]; 
  146.       (V)=def_temp; }
  147. #else
  148. #define mi_float4store(T,A)  { *(T)= ((byte *) &A)[3];
  149.        *((T)+1)=(char) ((byte *) &A)[2];
  150.        *((T)+2)=(char) ((byte *) &A)[1];
  151.        *((T)+3)=(char) ((byte *) &A)[0]; }
  152. #define mi_float4get(V,M)   { float def_temp;
  153.       ((byte*) &def_temp)[0]=(M)[3];
  154.       ((byte*) &def_temp)[1]=(M)[2];
  155.       ((byte*) &def_temp)[2]=(M)[1];
  156.       ((byte*) &def_temp)[3]=(M)[0];
  157.       (V)=def_temp; }
  158. #if defined(__FLOAT_WORD_ORDER) && (__FLOAT_WORD_ORDER == __BIG_ENDIAN)
  159. #define mi_float8store(T,V) { *(T)= ((byte *) &V)[3];
  160.       *((T)+1)=(char) ((byte *) &V)[2];
  161.       *((T)+2)=(char) ((byte *) &V)[1];
  162.       *((T)+3)=(char) ((byte *) &V)[0];
  163.       *((T)+4)=(char) ((byte *) &V)[7];
  164.       *((T)+5)=(char) ((byte *) &V)[6];
  165.       *((T)+6)=(char) ((byte *) &V)[5];
  166.       *((T)+7)=(char) ((byte *) &V)[4];}
  167. #define mi_float8get(V,M)   { double def_temp;
  168.       ((byte*) &def_temp)[0]=(M)[3];
  169.       ((byte*) &def_temp)[1]=(M)[2];
  170.       ((byte*) &def_temp)[2]=(M)[1];
  171.       ((byte*) &def_temp)[3]=(M)[0];
  172.       ((byte*) &def_temp)[4]=(M)[7];
  173.       ((byte*) &def_temp)[5]=(M)[6];
  174.       ((byte*) &def_temp)[6]=(M)[5];
  175.       ((byte*) &def_temp)[7]=(M)[4];
  176.       (V)=def_temp; }
  177. #else
  178. #define mi_float8store(T,V) { *(T)= ((byte *) &V)[7];
  179.       *((T)+1)=(char) ((byte *) &V)[6];
  180.       *((T)+2)=(char) ((byte *) &V)[5];
  181.       *((T)+3)=(char) ((byte *) &V)[4];
  182.       *((T)+4)=(char) ((byte *) &V)[3];
  183.       *((T)+5)=(char) ((byte *) &V)[2];
  184.       *((T)+6)=(char) ((byte *) &V)[1];
  185.       *((T)+7)=(char) ((byte *) &V)[0];}
  186. #define mi_float8get(V,M)   { double def_temp;
  187.       ((byte*) &def_temp)[0]=(M)[7];
  188.       ((byte*) &def_temp)[1]=(M)[6];
  189.       ((byte*) &def_temp)[2]=(M)[5];
  190.       ((byte*) &def_temp)[3]=(M)[4];
  191.       ((byte*) &def_temp)[4]=(M)[3];
  192.       ((byte*) &def_temp)[5]=(M)[2];
  193.       ((byte*) &def_temp)[6]=(M)[1];
  194.       ((byte*) &def_temp)[7]=(M)[0];
  195.       (V)=def_temp; }
  196. #endif /* __FLOAT_WORD_ORDER */
  197. #endif /* WORDS_BIGENDIAN */
  198. /* Fix to avoid warnings when sizeof(ha_rows) == sizeof(long) */
  199. #ifdef BIG_TABLE
  200. #define mi_rowstore(T,A)    mi_int8store(T,A)
  201. #define mi_rowkorr(T,A)     mi_uint8korr(T)
  202. #else
  203. #define mi_rowstore(T,A)    { mi_int4store(T,0); mi_int4store(((T)+4),A); }
  204. #define mi_rowkorr(T)     mi_uint4korr((T)+4)
  205. #endif
  206. #if SIZEOF_OFF_T > 4
  207. #define mi_sizestore(T,A)    mi_int8store(T,A)
  208. #define mi_sizekorr(T)      mi_uint8korr(T)
  209. #else
  210. #define mi_sizestore(T,A)    { if ((A) == HA_OFFSET_ERROR) bfill((char*) (T),8,255);  else { mi_int4store((T),0); mi_int4store(((T)+4),A); }}
  211. #define mi_sizekorr(T)   mi_uint4korr((T)+4)
  212. #endif