Jedi.inc
上传用户:hylc_2004
上传日期:2014-01-23
资源大小:46800k
文件大小:17k
源码类别:

Delphi控件源码

开发平台:

Delphi

  1. {******************************************************************************}
  2. {                                                                              }
  3. { The contents of this file are subject to the Mozilla Public License Version  }
  4. { 1.1 (the "License"); you may not use this file except in compliance with the }
  5. { License. You may obtain a copy of the License at http://www.mozilla.org/MPL/ }
  6. {                                                                              }
  7. { Software distributed under the License is distributed on an "AS IS" basis,   }
  8. { WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for }
  9. { the specific language governing rights and limitations under the License.    }
  10. {                                                                              }
  11. { The Original Code is jedi.inc.                                               }
  12. {                                                                              }
  13. { The Initial Developer of the Original Code is Project JEDI                   }
  14. { http://www.delphi-jedi.org                                                   }
  15. {                                                                              }
  16. {******************************************************************************}
  17. {                                                                              }
  18. { This file defines various generic compiler directives used in the JEDI Code  }
  19. { Library (JCL) and JEDI Visual Component Library Library (J-VCL). The         }
  20. { directives in this file are of generic nature and consist mostly of mappings }
  21. { from the VERXXX directives defined by Delphi and C++ Builder to friendly     }
  22. { names such as DELPHI5 and SUPPORTS_WIDESTRING. These friendly names are      }
  23. { subsequently used in both libraries to test for compiler versions and/or     }
  24. { whether the compiler supports certain features (such as widestring's or 64   }
  25. { bit integers. Both libraries provide an additional, library specific,        }
  26. { include file. For the JCL this is JCL.INC. These files should be included in }
  27. { source files instead of this file (which is pulled in automatically).        }
  28. {                                                                              }
  29. { Maintainer: Marcel van Brakel                                                }
  30. { Last modified: 2003-07-14, Peter J. Haas (jediplus@pjh2.de)                  }
  31. {                                                                              }
  32. {******************************************************************************}
  33. (*
  34. - Development environment directives
  35.   This file defines two driectives to indicate which development environment the
  36.   library is being compiled with. Currently this can either be Delphi or
  37.   C++ Builder (in the near future "Kylix" will be added).
  38.   Directive    Description
  39.   ------------------------------------------------------------------------------
  40.   DELPHI       Defined if compiled with Delphi
  41.   BCB          Defined if compiled with C++ Builder
  42. - Platform Directives
  43.   Platform directives are not explicitly defined in this file but are defined
  44.   by the compiler itself. They are listed here only for completeness.
  45.   Directive    Description
  46.   ------------------------------------------------------------------------------
  47.   WIN32        Defined when target platform is 32 bit Windows
  48.   LINUX        Defined when target platform is Linux
  49. - Delphi Versions
  50.   The following directives are direct mappings from the VERXXX directives to a
  51.   friendly name of the associated compiler. These directives are only defined if
  52.   the compiler is Delphi (ie DELPHI is defined).
  53.   Directive    Description
  54.   ------------------------------------------------------------------------------
  55.   DELPHI1      Defined when compiling with Delphi 1
  56.   DELPHI2      Defined when compiling with Delphi 2
  57.   DELPHI3      Defined when compiling with Delphi 3
  58.   DELPHI4      Defined when compiling with Delphi 4
  59.   DELPHI5      Defined when compiling with Delphi 5
  60.   DELPHI6      Defined when compiling with Delphi 6
  61.   DELPHI7      Defined when compiling with Delphi 7
  62.   DELPHI1_UP   Defined when compiling with Delphi 1 or higher
  63.   DELPHI2_UP   Defined when compiling with Delphi 2 or higher
  64.   DELPHI3_UP   Defined when compiling with Delphi 3 or higher
  65.   DELPHI4_UP   Defined when compiling with Delphi 4 or higher
  66.   DELPHI5_UP   Defined when compiling with Delphi 5 or higher
  67.   DELPHI6_UP   Defined when compiling with Delphi 6 or higher
  68.   DELPHI7_UP   Defined when compiling with Delphi 7 or higher
  69. - C++ Builder Versions
  70.   The following directives are direct mappings from the VERXXX directives to a
  71.   friendly name of the associated compiler. These directives are only defined if
  72.   the compiler is C++ Builder (ie BCB is defined).
  73.   Directive    Description
  74.   ------------------------------------------------------------------------------
  75.   BCB1         Defined when compiling with C++ Builder 1
  76.   BCB3         Defined when compiling with C++ Builder 3
  77.   BCB4         Defined when compiling with C++ Builder 4
  78.   BCB5         Defined when compiling with C++ Builder 5
  79.   BCB6         Defined when compiling with C++ Builder 6
  80.   BCB7         Defined when compiling with C++ Builder 7
  81.   BCB1_UP      Defined when compiling with C++ Builder 1 or higher
  82.   BCB3_UP      Defined when compiling with C++ Builder 3 or higher
  83.   BCB4_UP      Defined when compiling with C++ Builder 4 or higher
  84.   BCB5_UP      Defined when compiling with C++ Builder 5 or higher
  85.   BCB6_UP      Defined when compiling with C++ Builder 6 or higher
  86.   BCB7_UP      Defined when compiling with C++ Builder 7 or higher
  87. - Compiler Versions
  88.   The following directives are direct mappings from the VERXXX directives to a
  89.   friendly name of the associated compiler. Unlike the DELPHI_X and BCB_X
  90.   directives, these directives are indepedent of the development environment.
  91.   That is, they are defined regardless of whether compilation takes place using
  92.   Delphi or C++ Builder.
  93.   Directive     Description
  94.   ------------------------------------------------------------------------------
  95.   COMPILER1     Defined when compiling with Delphi 1
  96.   COMPILER2     Defined when compiling with Delphi 2 or C++ Builder 1
  97.   COMPILER3     Defined when compiling with Delphi 3
  98.   COMPILER35    Defined when compiling with C++ Builder 3
  99.   COMPILER4     Defined when compiling with Delphi 4 or C++ Builder 4
  100.   COMPILER5     Defined when compiling with Delphi 5 or C++ Builder 5
  101.   COMPILER6     Defined when compiling with Delphi 6 or C++ Builder 6
  102.   COMPILER7     Defined when compiling with Delphi 7 or C++ Builder 7
  103.   COMPILER1_UP  Defined when compiling with Delphi 1 or higher
  104.   COMPILER2_UP  Defined when compiling with Delphi 2 or C++ Builder 1 or higher
  105.   COMPILER3_UP  Defined when compiling with Delphi 3 or higher
  106.   COMPILER35_UP Defined when compiling with C++ Builder 3 or higher
  107.   COMPILER4_UP  Defined when compiling with Delphi 4 or C++ Builder 4 or higher
  108.   COMPILER5_UP  Defined when compiling with Delphi 5 or C++ Builder 5 or higher
  109.   COMPILER6_UP  Defined when compiling with Delphi 6 or C++ Builder 6 or higher
  110.   COMPILER7_UP  Defined when compiling with Delphi 7 or C++ Builder 6 or higher
  111. - Feature Directives
  112.   The features directives are used to test if the compiler supports specific
  113.   features, such as method overloading, and adjust the sources accordingly. Use
  114.   of these directives is preferred over the use of the DELPHI and COMPILER
  115.   directives.
  116.   Directive              Description
  117.   ------------------------------------------------------------------------------
  118.   SUPPORTS_WIDESTRING    Compiler supports the WideString type (D3/BCB3 up)
  119.   SUPPORTS_INTERFACE     Compiler supports interfaces (D3/BCB3)
  120.   SUPPORTS_EXTSYM        Compiler supports the $EXTERNALSYM directive (D4/BCB3)
  121.   SUPPORTS_NODEFINE      Compiler supports the $NODEFINE directive (D4/BCB3)
  122.   SUPPORTS_INT64         Compiler supports the Int64 type (D4/BCB4)
  123.   SUPPORTS_DYNAMICARRAYS Compiler supports dynamic arrays (D4/BCB4)
  124.   SUPPORTS_DEFAULTPARAMS Compiler supports default parameters (D4/BCB4)
  125.   SUPPORTS_OVERLOAD      Compiler supports overloading (D4/BCB4)
  126. - Compiler Settings
  127.   The compiler settings directives indicate whether a specific compiler setting
  128.   is in effect. This facilitates changing compiler settings locally in a more
  129.   compact and readible manner.
  130.   Directive              Description
  131.   ------------------------------------------------------------------------------
  132.   ALIGN_ON               Compiling in the A+ state (no alignment)
  133.   BOOLEVAL_ON            Compiling in the B+ state (complete boolean evaluation)
  134.   ASSERTIONS_ON          Compiling in the C+ state (assertions on)
  135.   DEBUGINFO_ON           Compiling in the D+ state (debug info generation on)
  136.   IMPORTEDDATA_ON        Compiling in the G+ state (creation of imported data references)
  137.   LONGSTRINGS_ON         Compiling in the H+ state (string defined as AnsiString)
  138.   IOCHECKS_ON            Compiling in the I+ state (I/O checking enabled)
  139.   WRITEABLECONST_ON      Compiling in the J+ state (typed constants can be modified)
  140.   LOCALSYMBOLS           Compiling in the L+ state (local symbol generation)
  141.   TYPEINFO_ON            Compiling in the M+ state (RTTI generation on)
  142.   OPTIMIZATION_ON        Compiling in the O+ state (code optimization on)
  143.   OPENSTRINGS_ON         Compiling in the P+ state (variable string parameters are openstrings)
  144.   OVERFLOWCHECKS_ON      Compiling in the Q+ state (overflow checing on)
  145.   RANGECHECKS_ON         Compiling in the R+ state (range checking on)
  146.   TYPEDADDRESS_ON        Compiling in the T+ state (pointers obtained using the @ operator are typed)
  147.   SAFEDIVIDE_ON          Compiling in the U+ state (save FDIV instruction through RTL emulation)
  148.   VARSTRINGCHECKS_ON     Compiling in the V+ state (type checking of shortstrings)
  149.   STACKFRAMES_ON         Compiling in the W+ state (generation of stack frames)
  150.   EXTENDEDSYNTAX_ON      Compiling in the X+ state (Delphi extended syntax enabled)
  151. *)
  152. //------------------------------------------------------------------------------
  153. // Compiler settings
  154. //------------------------------------------------------------------------------
  155. {$IFOPT A+} {$DEFINE ALIGN_ON} {$ENDIF}
  156. {$IFOPT B+} {$DEFINE BOOLEVAL_ON} {$ENDIF}
  157. {$IFOPT C+} {$DEFINE ASSERTIONS_ON} {$ENDIF}
  158. {$IFOPT D+} {$DEFINE DEBUGINFO_ON} {$ENDIF}
  159. {$IFOPT G+} {$DEFINE IMPORTEDDATA_ON} {$ENDIF}
  160. {$IFOPT H+} {$DEFINE LONGSTRINGS_ON} {$ENDIF}
  161. //HINTS
  162. {$IFOPT I+} {$DEFINE IOCHECKS_ON} {$ENDIF}
  163. {$IFOPT J+} {$DEFINE WRITEABLECONST_ON} {$ENDIF}
  164. {$IFOPT L+} {$DEFINE LOCALSYMBOLS} {$ENDIF}
  165. {$IFOPT M+} {$DEFINE TYPEINFO_ON} {$ENDIF}
  166. {$IFOPT O+} {$DEFINE OPTIMIZATION_ON} {$ENDIF}
  167. {$IFOPT P+} {$DEFINE OPENSTRINGS_ON} {$ENDIF}
  168. {$IFOPT Q+} {$DEFINE OVERFLOWCHECKS_ON} {$ENDIF}
  169. {$IFOPT R+} {$DEFINE RANGECHECKS_ON} {$ENDIF}
  170. //REALCOMPATIBILITY
  171. {$IFOPT T+} {$DEFINE TYPEDADDRESS_ON} {$ENDIF}
  172. {$IFOPT U+} {$DEFINE SAFEDIVIDE_ON} {$ENDIF}
  173. {$IFOPT V+} {$DEFINE VARSTRINGCHECKS_ON} {$ENDIF}
  174. {$IFOPT W+} {$DEFINE STACKFRAMES_ON} {$ENDIF}
  175. //WARNINGS
  176. {$IFOPT X+} {$DEFINE EXTENDEDSYNTAX_ON} {$ENDIF}
  177. //------------------------------------------------------------------------------
  178. // VERXXX to COMPILERX, DELPHIX and BCBX mappings
  179. //------------------------------------------------------------------------------
  180. {$IFDEF VER150}
  181.   {$DEFINE COMPILER7}
  182.   {$IFDEF BCB}
  183.     {$DEFINE BCB7}
  184.     {$DEFINE BCB}
  185.   {$ELSE}
  186.     {$DEFINE DELPHI7}
  187.     {$DEFINE DELPHI}
  188.   {$ENDIF}
  189. {$ENDIF}
  190. {$IFDEF VER140}
  191.   {$DEFINE COMPILER6}
  192.   {$IFDEF BCB}
  193.     {$DEFINE BCB6}
  194.     {$DEFINE BCB}
  195.   {$ELSE}
  196.     {$DEFINE DELPHI6}
  197.     {$DEFINE DELPHI}
  198.   {$ENDIF}
  199. {$ENDIF}
  200. {$IFDEF VER130}
  201.   {$DEFINE COMPILER5}
  202.   {$IFDEF BCB}
  203.     {$DEFINE BCB5}
  204.     {$DEFINE BCB}
  205.   {$ELSE}
  206.     {$DEFINE DELPHI5}
  207.     {$DEFINE DELPHI}
  208.   {$ENDIF}
  209. {$ENDIF}
  210. {$IFDEF VER125}
  211.   {$DEFINE COMPILER4}
  212.   {$DEFINE BCB4}
  213.   {$DEFINE BCB}
  214. {$ENDIF}
  215. {$IFDEF VER120}
  216.   {$DEFINE COMPILER4}
  217.   {$DEFINE DELPHI4}
  218.   {$DEFINE DELPHI}
  219. {$ENDIF}
  220. {$IFDEF VER110}
  221.   {$DEFINE COMPILER35}
  222.   {$DEFINE BCB3}
  223. {$ENDIF}
  224. {$IFDEF VER100}
  225.   {$DEFINE COMPILER3}
  226.   {$DEFINE DELPHI3}
  227.   {$DEFINE DELPHI}
  228. {$ENDIF}
  229. {$IFDEF VER93}
  230.   {$DEFINE COMPILER2}
  231.   {$DEFINE BCB1}
  232.   {$DEFINE BCB}
  233. {$ENDIF}
  234. {$IFDEF VER90}
  235.   {$DEFINE COMPILER2}
  236.   {$DEFINE DELPHI2}
  237.   {$DEFINE DELPHI}
  238. {$ENDIF}
  239. {$IFDEF VER80}
  240.   {$DEFINE COMPILER1}
  241.   {$DEFINE DELPHI1}
  242.   {$DEFINE DELPHI}
  243. {$ENDIF}
  244. //------------------------------------------------------------------------------
  245. // DELPHIX_UP from DELPHIX mappings
  246. //------------------------------------------------------------------------------
  247. {$IFDEF DELPHI7}
  248.   {$DEFINE DELPHI7_UP}
  249.   {$DEFINE DELPHI6_UP}
  250.   {$DEFINE DELPHI5_UP}
  251.   {$DEFINE DELPHI4_UP}
  252.   {$DEFINE DELPHI3_UP}
  253.   {$DEFINE DELPHI2_UP}
  254.   {$DEFINE DELPHI1_UP}
  255. {$ENDIF}
  256. {$IFDEF DELPHI6}
  257.   {$DEFINE DELPHI6_UP}
  258.   {$DEFINE DELPHI5_UP}
  259.   {$DEFINE DELPHI4_UP}
  260.   {$DEFINE DELPHI3_UP}
  261.   {$DEFINE DELPHI2_UP}
  262.   {$DEFINE DELPHI1_UP}
  263. {$ENDIF}
  264. {$IFDEF DELPHI5}
  265.   {$DEFINE DELPHI5_UP}
  266.   {$DEFINE DELPHI4_UP}
  267.   {$DEFINE DELPHI3_UP}
  268.   {$DEFINE DELPHI2_UP}
  269.   {$DEFINE DELPHI1_UP}
  270. {$ENDIF}
  271. {$IFDEF DELPHI4}
  272.   {$DEFINE DELPHI4_UP}
  273.   {$DEFINE DELPHI3_UP}
  274.   {$DEFINE DELPHI2_UP}
  275.   {$DEFINE DELPHI1_UP}
  276. {$ENDIF}
  277. {$IFDEF DELPHI3}
  278.   {$DEFINE DELPHI3_UP}
  279.   {$DEFINE DELPHI2_UP}
  280.   {$DEFINE DELPHI1_UP}
  281. {$ENDIF}
  282. {$IFDEF DELPHI2}
  283.   {$DEFINE DELPHI2_UP}
  284.   {$DEFINE DELPHI1_UP}
  285. {$ENDIF}
  286. {$IFDEF DELPHI1}
  287.   {$DEFINE DELPHI1_UP}
  288. {$ENDIF}
  289. //------------------------------------------------------------------------------
  290. // BCBX_UP from BCBX mappings
  291. //------------------------------------------------------------------------------
  292. {$IFDEF BCB7}
  293.   {$DEFINE BCB7_UP}
  294.   {$DEFINE BCB6_UP}
  295.   {$DEFINE BCB5_UP}
  296.   {$DEFINE BCB4_UP}
  297.   {$DEFINE BCB3_UP}
  298.   {$DEFINE BCB1_UP}
  299. {$ENDIF}
  300. {$IFDEF BCB6}
  301.   {$DEFINE BCB6_UP}
  302.   {$DEFINE BCB5_UP}
  303.   {$DEFINE BCB4_UP}
  304.   {$DEFINE BCB3_UP}
  305.   {$DEFINE BCB1_UP}
  306. {$ENDIF}
  307. {$IFDEF BCB5}
  308.   {$DEFINE BCB5_UP}
  309.   {$DEFINE BCB4_UP}
  310.   {$DEFINE BCB3_UP}
  311.   {$DEFINE BCB1_UP}
  312. {$ENDIF}
  313. {$IFDEF BCB4}
  314.   {$DEFINE BCB4_UP}
  315.   {$DEFINE BCB3_UP}
  316.   {$DEFINE BCB1_UP}
  317. {$ENDIF}
  318. {$IFDEF BCB3}
  319.   {$DEFINE BCB3_UP}
  320.   {$DEFINE BCB1_UP}
  321. {$ENDIF}
  322. {$IFDEF BCB1}
  323.   {$DEFINE BCB1_UP}
  324. {$ENDIF}
  325. //------------------------------------------------------------------------------
  326. // COMPILERX_UP from COMPILERX mappings
  327. //------------------------------------------------------------------------------
  328. {$IFDEF COMPILER7}
  329.   {$DEFINE COMPILER7_UP}
  330.   {$DEFINE COMPILER6_UP}
  331.   {$DEFINE COMPILER5_UP}
  332.   {$DEFINE COMPILER4_UP}
  333.   {$DEFINE COMPILER35_UP}
  334.   {$DEFINE COMPILER3_UP}
  335.   {$DEFINE COMPILER2_UP}
  336.   {$DEFINE COMPILER1_UP}
  337. {$ENDIF}
  338. {$IFDEF COMPILER6}
  339.   {$DEFINE COMPILER6_UP}
  340.   {$DEFINE COMPILER5_UP}
  341.   {$DEFINE COMPILER4_UP}
  342.   {$DEFINE COMPILER35_UP}
  343.   {$DEFINE COMPILER3_UP}
  344.   {$DEFINE COMPILER2_UP}
  345.   {$DEFINE COMPILER1_UP}
  346. {$ENDIF}
  347. {$IFDEF COMPILER5}
  348.   {$DEFINE COMPILER5_UP}
  349.   {$DEFINE COMPILER4_UP}
  350.   {$DEFINE COMPILER35_UP}
  351.   {$DEFINE COMPILER3_UP}
  352.   {$DEFINE COMPILER2_UP}
  353.   {$DEFINE COMPILER1_UP}
  354. {$ENDIF}
  355. {$IFDEF COMPILER4}
  356.   {$DEFINE COMPILER4_UP}
  357.   {$DEFINE COMPILER35_UP}
  358.   {$DEFINE COMPILER3_UP}
  359.   {$DEFINE COMPILER2_UP}
  360.   {$DEFINE COMPILER1_UP}
  361. {$ENDIF}
  362. {$IFDEF COMPILER35}
  363.   {$DEFINE COMPILER35_UP}
  364.   {$DEFINE COMPILER3_UP}
  365.   {$DEFINE COMPILER2_UP}
  366.   {$DEFINE COMPILER1_UP}
  367. {$ENDIF}
  368. {$IFDEF COMPILER3}
  369.   {$DEFINE COMPILER3_UP}
  370.   {$DEFINE COMPILER2_UP}
  371.   {$DEFINE COMPILER1_UP}
  372. {$ENDIF}
  373. {$IFDEF COMPILER2}
  374.   {$DEFINE COMPILER2_UP}
  375.   {$DEFINE COMPILER1_UP}
  376. {$ENDIF}
  377. {$IFDEF COMPILER1}
  378.   {$DEFINE COMPILER1_UP}
  379. {$ENDIF}
  380. //------------------------------------------------------------------------------
  381. // Map COMPILERX_UP to friendly feature names
  382. //------------------------------------------------------------------------------
  383. {$IFDEF COMPILER3_UP}
  384.   {$DEFINE SUPPORTS_WIDESTRING}
  385.   {$DEFINE SUPPORTS_INTERFACE}
  386. {$ENDIF}
  387. {$IFDEF COMPILER35_UP}
  388.   {$DEFINE SUPPORTS_EXTSYM}
  389.   {$DEFINE SUPPORTS_NODEFINE}
  390. {$ENDIF}
  391. {$IFDEF COMPILER4_UP}
  392.   {$DEFINE SUPPORTS_INT64}
  393.   {$DEFINE SUPPORTS_DYNAMICARRAYS}
  394.   {$DEFINE SUPPORTS_DEFAULTPARAMS}
  395.   {$DEFINE SUPPORTS_OVERLOAD}
  396. {$ENDIF}
  397. //------------------------------------------------------------------------------
  398. // Cross-platform related defines
  399. //------------------------------------------------------------------------------
  400. {$IFDEF WIN32}
  401.   {$DEFINE MSWINDOWS}
  402. {$ENDIF}
  403. {$IFDEF LINUX}
  404.   {$DEFINE UNIX}
  405.   {$DEFINE COMPLIB_CLX}
  406. {$ENDIF}
  407. {$IFNDEF COMPLIB_CLX}
  408.   {$DEFINE COMPLIB_VCL}
  409. {$ENDIF}