home *** CD-ROM | disk | FTP | other *** search
/ Liren Large Software Subsidy 7 / 07.iso / c / c083 / 1.ddi / README.TXT < prev    next >
Encoding:
Text File  |  1993-12-02  |  44.7 KB  |  1,110 lines

  1.                    Welcome to Borland C++ 4.0
  2.                    --------------------------
  3.  
  4.   This README file contains important information about Borland C++.
  5.   For the latest information about Borland C++ and its accompanying
  6.   programs and manuals, read this entire file.
  7.  
  8. -----------------
  9. TABLE OF CONTENTS
  10. -----------------
  11. 1.  How to Get Help
  12. 2.  Installation
  13. 3.  Features
  14.      -Compiler
  15.      -Linker
  16.      -IDE
  17.      -Turbo Debugger
  18.      -Resource Workshop
  19.      -ObjectWindows Library (OWL)
  20.      -VBX Support
  21.      -Documentation
  22. 4.  Important Information
  23.      -General
  24.      -New Tools
  25.      -Running from a Windows 3.1 DOS Prompt
  26.      -C/C++ Language Changes
  27.      -Developing for NT
  28.      -Libraries and Startup Code
  29.      -New Compiler and Linker Switches
  30.      -Converting Your Borland C++ 3.1 Windows Code to Borland C++ 4.0
  31.      -Class Libraries
  32.      -Casting Macros
  33.      -IDE/Integrated Debugging
  34.      -Floating Point Formats
  35.      -Turbo Debugger for Windows
  36.      -Using Tools with NTFS
  37.  
  38. ------------------
  39. 1. HOW TO GET HELP
  40. ------------------
  41.  
  42.   If you have any problems, please read this file, the
  43.   HELPME!.DOC and other files in your DOC subdirectory, and
  44.   check the on-line help and the Borland C++ manuals first.
  45.   If you still have a question and need assistance, help is
  46.   available from the following sources:
  47.  
  48.   1. For instant on-line access to the Borland forums with
  49.      their libraries of technical information and answers
  50.      to common questions, type
  51.  
  52.         GO BCPPDOS     - for questions pertaining to DOS
  53.  
  54.          or
  55.  
  56.         GO BCPPWIN     - for questions pertaining to Windows
  57.  
  58.      If you are not a member of CompuServe, see the enclosed
  59.      special offer, and write for full details on how to receive
  60.      a free IntroPak containing a $15 credit toward your first
  61.      month's on-line charges.
  62.  
  63.   2. Borland offers a wide variety of Technical Support plans
  64.      providing a range of assistance from installation and general
  65.      usage of Borland C++ to language syntax, programming, and
  66.      debugging help. For information about these support programs,
  67.      call 1-800-523-7070.
  68.  
  69.   3. Borland's TECHFAX service. Call (800) 822-4269 for a FAX
  70.       catalog of technical document entries.
  71.  
  72.   4. Borland DLBBS. Dial (408) 431-5096 (up to 9600 baud, 8-N-1)
  73.       for a host of free technical documents and example programs.
  74.  
  75.   5. For immediate assistance with everything from configuring Borland C++
  76.       to programming or debugging, call our C++ Programmer's
  77.       Advisor Lines ($2/minute, first minute free):
  78.             * Windows / Win32:    1-900-555-1002  or 1-800-782-5558 (MC/Visa)
  79.             * DOS :        1-900-555-1004  or 1-800-368-3366 (MC/Visa)
  80.  
  81. ---------------
  82. 2. INSTALLATION
  83. ---------------
  84. Important!
  85. ----------
  86. Do not install Borland C++ 4.0 files over previously installed Borland
  87. C++ directories. The files in this distribution will not work
  88. with previously shipped tools and libraries.  This is particularly
  89. true for configuration files from previous shipping
  90. releases, like TDCONFIG.TDW and BCCONFIG.BCW.
  91.  
  92. Also, be especially careful when using object files and libraries
  93. from Borland C++ 3.1 with binaries created with this release. There are 
  94. several potential problems when linking with old objects or libraries. 
  95. Exceptions won't work correctly (destructors won't get called) when a 
  96. pre-BC4 stack frame is unwound due to an exception. Also, if a constructor 
  97. or destructor compiled with a pre-BC4 compiler is involved in exception 
  98. unwinding, trouble may occur. Another potential problem is when an RTTI class 
  99. is shared with pre-BC4 code; some cases of that will be caught by the linker,
  100. but others may fail mysteriously. Try using the -K2 switch to get pre-BC4 code
  101. to link. Note: these problems are C++ specific. C objects between versions
  102. should be more readily compatible.
  103.  
  104. Installing Borland C++ 4.0 on your hard disk:
  105. --------------------------------------
  106. Installing from floppy disks:
  107.     1. Select File|Run from Windows 3.1, Windows for Workgroups 3.1x,
  108.        or Windows NT.
  109.     2. Enter A:INSTALL (or B:INSTALL) on the input line.
  110.     3. Under "Installation Options", you have the option of not
  111.        installing Win32s, which should be turned off if you are 
  112.        installing under Windows NT.
  113.           (NOTE that BCW does not run under NT, so if you are only using
  114.           NT, you may wish to not install it.)
  115.     4. Fill in directories as appropriate, and INSTALL will create
  116.           appropriate Windows groups, install Win32s, and install the
  117.        new Borland C++ 4.0 software according to the directories you select.
  118.  
  119. Installing from the CDROM:
  120.     1. Go to the CDROM, and change directories to INSTALL.
  121.     2. Select File|Run from Windows 3.1, Windows for Workgroups 3.1x,
  122.        or Windows NT.
  123.     3. Enter X:INSTALL on the input line (where X: is your CDROM drive).
  124.     4. Under "Installation Options", you have the option of not
  125.        installing Win32s, which should be turned off if you are
  126.        installing under Windows NT.
  127.     5. Fill in directories as appropriate, and INSTALL will create
  128.        appropriate Windows groups, install Win32s, and install the
  129.        new Borland C++ 4.0 software according to the directories you select.
  130.  
  131. To use the built-in transfer tools and Help, make sure their location is
  132. in your path (the \BIN directory for Borland C++ 4.0).
  133.  
  134. After installing, make sure your path is set correctly, and restart 
  135. Windows before using Borland C++ 4.0.
  136.  
  137. NOTE: If you want to install the Win32s debug kernel, use the
  138. SWITCH.BAT file provided with the Microsoft Win32s tools, found on the
  139. NT SDK CD-ROM distribution.  This will ensure that the proper files
  140. are copied to the appropriate places.  Not copying the files correctly 
  141. will result in obscure load errors. 
  142.  
  143. Configuring Borland Pascal and Borland C++
  144. ------------------------------------------
  145. The install program for Borland C++ 4.0 will configure your system to
  146. allow the use of Borland C++ 4.0 and Borland Pascal 7.0 on the same
  147. machine.  As long as you have installed Borland Pascal prior to
  148. (rather than after) installing Borland C++ there are very few
  149. guidelines you must follow:
  150.  
  151. - The two Windows hosted IDEs may not be run simultaneously.
  152.  
  153. - Each must use their respective copies of tools and utilities that
  154.   depend on debug information, most notably Turbo Debugger for Windows
  155.   (TDW).  You may find it useful to rename the Borland Pascal version
  156.   of TDW.EXE to something like BPTDW.EXE to avoid confusing filenames
  157.   in your path.
  158.  
  159. - Both versions of TDW may not be run simultaneously.
  160.  
  161. - Make sure that old copies of TDW.INI are removed from your system. 
  162.   (Running the utility TDWINI.EXE will make sure that this takes
  163.   place.)
  164.  
  165. That's all there is to it!  To reduce disk space requirements, you
  166. may wish to remove duplicate versions of utilities that do not
  167. require debug information, such as WinSight and Resource Workshop. 
  168. In these cases, you will want to use the versions that came with
  169. Borland C++ 4.0 so that you will have the latest features.
  170.  
  171. If you wish to use TDWGUI.DLL with TDW version 3.1 you need to
  172. manually add UseTimer=Yes to the VideoOptions section of TDW.INI. 
  173. Note that this option should not be set when using TDW version 4.0. 
  174. This means that you would need to hand change your TDW.INI file each
  175. time you switched between versions of TDW.  For this reason, we
  176. recommend the non-windowed video DLLs (such as SVGA.DLL) for
  177. customers who debug both BP and BC applications.
  178.  
  179. If you are installing Borland Pascal 7.0 AFTER Borland C++ 4.0 has
  180. been installed, you will have to manually change the system settings
  181. that allow these products to coexist:
  182.  
  183. In your system.ini file, check your [386Enh] section for multiple
  184. entries for the device TDDEBUG.386.  Remove duplicate entries of
  185. TDDEBUG.386 so that only the version from Borland C++ is loaded.  On
  186. disk, you may also want to rename or remove the BP7 versions of
  187. TDDEBUG.386 and TDWIN.DLL to avoid their accidental loading.  You
  188. must restart Windows after making changes to system.ini.
  189.  
  190. Win32s and minimum swap file size
  191. ---------------------------------
  192. Borland recommends that you have a minimum of 12 MB of memory available to
  193. run Win32s applications.  For example, if your machine has 8 MB of memory
  194. available to Windows, you should configure your "Virtual Memory" (swapfile)
  195. to at least 4 MB.  This will reduce the risk of out-of-memory errors 
  196. occuring in Win32s.
  197.  
  198. NT console applications and Win32s
  199. ----------------------------------
  200. There is no Win32s console, so attempting to run a Win32 console
  201. application without NT loaded will result in an error.
  202.  
  203. Changes to SYSTEM.INI file
  204. --------------------------
  205. The install program makes these changes to the SYSTEM.INI file:
  206.  
  207.   1) Adds "device=c:\bc4\bin\windpmi.386" to support our 32-bit tools.
  208.   2) Adds "device=c:\bc4\bin\tddebug.386" to support our debugger.
  209.  
  210.  
  211. Configuring the Windows NT command prompt
  212. -----------------------------------------
  213. To run 16-bit protected-mode programs (bcc, tlink) under an NT command prompt
  214. you need to add the following line to CONFIG.NT:
  215.  
  216.   ntcmdprompt
  217.  
  218. Under the default NT command-line prompt, DOS COMMAND.COM is run after
  219. returning from a TSR (such as RTM.EXE which bcc and tlink load). Adding the 
  220. above line will cause the original NT CMD.EXE to be run.
  221.  
  222.  
  223. Outdated versions of Win32s
  224. ---------------------------
  225. If you are running an outdated version of Win32s, the INSTALL program will
  226. instruct you to remove it before installation.  To remove an old
  227. version of Win32s perform the following steps:
  228.  
  229.   1. Change directory to the WINDOWS directory on your hard drive.  This
  230.      is most likely C:\WINDOWS.
  231.  
  232.   2. Edit the SYSTEM.INI file and remove the line in the [386Enh]
  233.      section that reads:
  234.  
  235.        device=C:\WINDOWS\SYSTEM\WIN32S\W32S.386
  236.  
  237.      (The actual path in the above line may be different to reflect your
  238.       configuration.)
  239.  
  240.   3. Change directory to the SYSTEM subdirectory.
  241.  
  242.   4. Remove the following files:
  243.  
  244.        W32SYS.DLL
  245.        WIN32S.INI
  246.        WIN32S16.DLL
  247.  
  248.   5. Change directory to the WIN32S subdirectory.
  249.  
  250.   6. Remove all files here.
  251.  
  252.   7. Change directory back to SYSTEM and remove the WIN32S subdirectory.
  253.  
  254. You will now be ready to run the INSTALL program.  Be sure to select
  255. <Install Win32s> in the INSTALL program so that the newer version of Win32s
  256. will be installed on your system.
  257.  
  258.  
  259. -----------
  260. 3. FEATURES
  261. -----------
  262.  
  263. Compiler:
  264. ---------
  265.   - Support for writing 16 and 32-bit Windows applications that target
  266.     Windows 3.1, Win32s and Windows NT, and 16-bit DOS applications.
  267.   - Pentium support.
  268.   - Support for ANSI C++ exception handling, structured exception handling
  269.     under C, and mixed C/C++ exception handling. All exception handling
  270.     constructs are available for both 16- and 32-bit.
  271.   - Additional optimizations and faster compile time.
  272.   - Support for ANSI C++ operator new[] and operator delete[].
  273.   - Runtime Library support for the ANSI C++ string class.
  274.   - Support for ANSI C++ runtime type identification (RTTI).
  275.   - Support for ANSI C++ new style casts dynamic_cast, static_cast, const_cast,
  276.     and  reinterpret_cast.
  277.   - Support for three character types as provided in ANSI C++.
  278.  
  279. Linker (16-bit and 32-bit):
  280. ---------------------------
  281.   - Now handles binding of resources; no need for a separate RC or
  282.     RLINK step.
  283.   - Linker debug capacity expanded.
  284.  
  285. IDE
  286. ---
  287.   - 16-bit DOS and Windows plus 32-bit Windows targeting from a single IDE.
  288.   - Integrated GUI debugging for 16-bit Windows applications.
  289.   - Includes both 16- and 32-bit tools (compiler, linker, resource 
  290.     compiler, resource binder, and library manager)  
  291.   - A new project manager that supports multiple targets, drag-and-drop,
  292.     and Style Sheets for associating options. 
  293.   - AppExpert, which simplifies the process of creating
  294.     ObjectWindows applications through code generation.
  295.   - ClassExpert, which simplifies adding and managing classes in
  296.     your AppExpert application.
  297.   - Transfers, Settings Notebook, SpeedMenus, and a configurable SpeedBar.
  298.   - Expanded editor support, including column blocking and window 
  299.     splitting.  TEMC now called KEYMAPR.
  300.   
  301. Turbo Debugger:
  302. ---------------
  303.   - Turbo Debugger (TD32) for Win32s and Windows NT.
  304.   - Support for OS exception handling.
  305.   - Support C/C++ exception handling.
  306.   - Windows NT thread support.
  307.   - Video DLL to run TDW in a window.
  308.   - Remote debugging with TDW.
  309.   - Session state saving.
  310.   - Process attach for Windows NT.
  311.   - Turbo Debugger Video Configuration Utility (TDWINI.EXE). 
  312.   - Built in large model for greater capacity.
  313.  
  314. Resource Workshop:
  315. ------------------
  316.   - Support for Win32s, Win32.
  317.   - Resource preview
  318.   - DialogExpert
  319.   - Auto ID numbering
  320.   - Auto mapping of accelerators and help hints to menu items
  321.   - Support for VBX controls
  322.   - SpeedMenus
  323.   - Dialog editor property inspector
  324.   - Integrated with ClassExpert and IDE project manager
  325.  
  326. ObjectWindows Library (OWL)
  327. ---------------------------
  328.   - Complete coverage of Windows API, including GDI
  329.   - Single source for Win 3.1, Win 32s, and NT
  330.   - Built in exception handling using standard C++ exceptions for robust error
  331.     handling
  332.   - Built-in type safety using standard C++ templates
  333.   - Toolbars, status lines, and print preview
  334.   - Flexible Document/View architecture
  335.   - Supports VBX 1.0 controls in a dialog or window
  336.   - Layout Windows
  337.   - Mix-in architecture
  338.   - Support for 3d controls
  339.   - Support for BWCC controls
  340.   - Gadgets and Widgets
  341.   - Multi threading support
  342.   - Printing and print previewing support
  343.  
  344. VBX Support
  345. -----------
  346. Borland's visual tools, such as Resource Workshop, provide support of VBX 1.0
  347. controls via a DLL called BIVBX10.DLL. You can freely distrubute this DLL
  348. with programs you create that use VBX controls.
  349.  
  350. BIVBX10.DLL has been tested with a large number of VBX controls written to the
  351. Microsoft Visual Basic 1.0 CDK specification. If you have a problem with a
  352. specific control, make sure that it does not require VB 2.0 or VB 3.0 CDK
  353. functionality. VBX 2.0 and 3.0 controls will usually display a message saying
  354. that they require VB 2.0 or 3.0 support. In some cases, though, the control may
  355. appear to work but exhibit instability. Please contact the control vendor and
  356. explain the problem. They may have an updated control or may be able to contact
  357. Borland to find a solution.
  358.  
  359. Documentation:
  360. --------------
  361. This distribution includes printed and online documentation
  362. to help you understand and use the new features of Borland C++ 4.0, as well
  363. as online Help.  
  364.  
  365. For C++ Language and Programming information:
  366.     See the Library Reference, the
  367.     Programmer's Guide, and the DOS Reference.
  368.     See also the online Help.
  369.  
  370. For information on using MAKE, TLINK, and resource tools:
  371.     See the User's Guide.
  372.     See also the online Help.
  373.  
  374. For information on keyboard mapping and KEYMAPR (used to be called TEMC):
  375.     See the online Help.
  376.  
  377. For information on using the IDE, AppExpert & ClassExpert, the Integrated
  378. Debugger, and compiling options:
  379.     See the User's Guide.
  380.     See also the online Help.
  381.  
  382. For information on using the new Project Manager:
  383.     See the online Help.
  384.  
  385. For information on converting your ObjectWindows 1.0 code to 
  386. ObjectWindows 2.0:
  387.     See the ObjectWindows Programmer's Guide.
  388.     See also the online text file owldoc.wri.
  389.     
  390. For information on programming in ObjectWindows 2.0: 
  391.     See the ObjectWindows Reference Guide, and the
  392.      ObjectWindows Programmer's Guide.
  393.     See also the online text file, owldoc.wri.
  394.  
  395. For help using Turbo Debugger:
  396.     See the online text files helpme!.tdw and hints.tdw.
  397.        See also the online Help.
  398.  
  399. To use the online Help, make sure the Borland C++ 4.0 \BIN directory is
  400. on your path.
  401.  
  402.  
  403. ------------------------
  404. 4. IMPORTANT INFORMATION
  405. ------------------------
  406. GENERAL
  407. -------
  408. Note that if you have only 8 MB of RAM, you might experience some out-of-memory
  409. problems building and using 32-bit applications. Please see the section below
  410. titled, "Out of memory and MAKESWAP".
  411.  
  412.  
  413. Object File Format
  414. ------------------
  415. This product is designed to use and generate only object files which adhere
  416. to the Intel OMF (Object Module Format) specification. This means that TLINK32
  417. and TLIB only accept files of this format, and all provided libraries use 
  418. this format. There is no support in the linker or librarian for COFF object
  419. modules produced by Microsoft C tools.
  420.  
  421. MAKE 
  422. ----
  423. MAKE will not put a space between two sets of file list macros as in BC++ 3.1
  424. and before.  The example makefile below illustrates this; simply execute MAKE
  425. in the directory containing the makefile. The output is:
  426.  
  427.    ALLOBJS1 = one onetwo two
  428.    ALLOBJS2 = one one two two
  429.  
  430. makefile:
  431.  
  432. OBJS1 = \
  433.    one \
  434.    one
  435.  
  436. OBJS2 = \
  437.    two \
  438.    two
  439.  
  440. ALLOBJS1 = $(OBJS1)$(OBJS2)
  441. ALLOBJS2 = $(OBJS1) $(OBJS2)
  442.  
  443. ..:
  444.  
  445.    @@echo ALLOBJS1 = $(ALLOBJS1)
  446.    @@echo ALLOBJS2 = $(ALLOBJS2)
  447.  
  448.  
  449. Out of Memory and MAKESWAP
  450. --------------------------
  451. If you get "Out of Memory" errors from DOS when running the
  452. command-line tools, create a swap file with the MAKESWAP utility.
  453. (Note that this applies to DOS only, not to DOS boxes opened under
  454. Windows.) MAKESWAP takes the size of the file to create in KBytes,
  455. for example:
  456.  
  457.   MAKESWAP 12000
  458.  
  459. will create a 12MB swap file in the current directory called EDPMI.SWP
  460. for use by Borland command line tools.  To enable the swap file, use
  461. the DPMI32 environment variable by issuing the following command at
  462. the DOS prompt:
  463.  
  464.   set DPMI32=SWAPFILE <location of swap file>\EDPMI.SWP
  465.  
  466. Note that you must clear this environment variable by issuing the
  467. command
  468.  
  469.   set DPMI32=
  470.  
  471. before running Paradox or other 16-bit DPMI-hosted executables,
  472. such as Borland C++ 3.1 command-line tools.
  473.  
  474. Threads
  475. -------
  476. When creating secondary threads, the _beginthread or _beginthreadNT and
  477. _endthread() RTL functions must be used to ensure the proper RTL
  478. initialization and cleanup. Using NT's CreateThread and ExitThread functions
  479. will result in undefined behavior if an implicit or explicit call is made to
  480. the RTL. Note that using exception handling and/or RTTI can lead to implicit
  481. RTL calls.
  482.  
  483.  
  484. DDVT functions and RTTI
  485. -----------------------
  486. When compiling code that contains DDVT functions, do not use run-time type
  487. information. If you attempt this, you will receive an error message. In order
  488. to compile without using run-time type information, compile all code that
  489. uses DDVTs (for instance OWL 1.0x libraries and applications) with the
  490. -RT- switch (Options|Project|C++ Options|Exception handling\RTTI in the IDE).
  491.  
  492. Inline assembly and interrupts
  493. ------------------------------
  494. If your inline assembly code includes an interrupt call, the compiler does not
  495. preserve any registers altered by the call. You must write code to save and
  496. restore registers when using interrupt calls within inline assembly code.
  497.  
  498. Obsolete Win32 functions
  499. ------------------------
  500. To discover when a function (such as DOS3Call) is obsolete under Win32, click
  501. on the hypertext link for "Win32 version" in Online Help. This leads to a new
  502. screen explaining that you can't use this function in Win32. When a
  503. function works differently in the two versions, a link appears on the
  504. first screen enabling the user to jump directly to help for the Win32
  505. version of the function.
  506.  
  507. BC4 path name
  508. ------------------
  509. Any occurrence of BORLANDC in the BC++ 4.0 path should be replaced with BC4.
  510.  
  511. Creating 16-bit import libraries from .DEF files
  512. ------------------------------------------------
  513. Use the /o implib switch when creating 16-bit import libraries from .DEF files
  514. to prevent implib from generating extensions for import entry module names.
  515.  
  516. Debugging DDE applications
  517. --------------------------
  518. DDE applications must be debugged in hard mode.
  519.  
  520.  
  521. ----------
  522. New Tools
  523. ----------
  524. The 16-bit linker has been modified in this version to allow for more than 64K
  525. symbols in the executable's symbol table. The following tools have changed to
  526. conform to the resulting new debug information format:
  527.  
  528.   TDW
  529.   TDUMP
  530.   Turbo Debugger (standalone)
  531.   IDE Debugger
  532.   IDE Browser
  533.  
  534. These tools have versioning information, so that if you attempt to use any of
  535. them with executables created in prior versions, an error message will result.
  536. You will then need to relink your executables.
  537.  
  538. If you don't see correct dump information when using TDUMP version 4.1 on your
  539. executables, check the header at the top of the output. If it does not indicate
  540. version 4.0 debug information, the associated .EXE file must be recompiled with
  541. version 4.0 tools.
  542.  
  543. -------------------------------------
  544. Running from a Windows 3.1 DOS Prompt
  545. -------------------------------------
  546. If you run BCC or TLINK from a Windows DOS box and you get
  547. out of memory errors, increase the XMS memory (in the 'Maximum'
  548. setting) allocated for the DOS box by editing the appropriate .PIF
  549. file (usually DOSPRMPT.PIF). BCC.EXE needs about 4MB to compile
  550. medium-sized .CPP files, and might need more memory for large .CPP
  551. files with debugging information.
  552.  
  553. NOTE: You must set the 'Maximum:' setting to the amount needed, not
  554.       the 'Required:' setting.  Using the 'Required:' setting only
  555.       sets aside memory for XMS, NOT for DPMI services and hence
  556.       any amount set in the 'Required:' setting box is unavailable.
  557.  
  558. -------------------
  559. Developing under NT
  560. -------------------
  561. To do development on NT, use the command-line tools, Resource
  562. Workshop, and TD32. Using the IDE under NT is not currently
  563. supported.
  564.  
  565. ----------------------
  566. C/C++ Language Changes
  567. ----------------------
  568. Many changes were made to the compiler in compliance with the 
  569. latest changes proposed by the ANSI C++ committee.  These include
  570. three distinct char types, enhancements to templates, support for
  571. virtual functions differing in return types, and other improvements
  572. listed here.  See the Library Reference and the Programmer's Guide
  573. for complete details on these changes and how they affect your 
  574. code.
  575.  
  576. wchar_t is a fundamental data type in C++ programs. In C programs it continues
  577. to be a typedef defined in stddef.h. See online Help.
  578.  
  579. Enum operator overloading is also supported in this compiler.
  580.  
  581. The runtime library now supports the ANSI C++ string class.
  582. If you already have a string class, it must be renamed for Borland C++ 4.0.
  583.  
  584. In addition, operator new and operator new[] now throw an
  585. exception (xalloc), as specified by the ANSI C++ committee.
  586. To get the old behavior, you can issue set_new_handler(0). (Note,
  587. however, that set_new_handler(0) does not work with ObjectWindows
  588. or string classes.) See Chapter 3 of the Programmer's Guide.
  589.  
  590. Note that arrays are now being allocated through operator new[]()
  591. and deleted by operator delete[](). An example is provided in 
  592. Chapter 3 of the Programmer's Guide.
  593.  
  594. Borland C++ 4.0 implements ANSI C++ runtime type identification (RTTI). See
  595. the Library Reference, "C++ runtime support",  for a description of
  596. class Type_info. RTTI and operator typeid() are fully described in
  597. Chapter 3 of the Programmer's Guide.
  598.  
  599. Borland C++ 4.0 provides a full implementation of exception handling
  600. under C++ and C.  C exceptions can be handled in C or C++ code;
  601. C++ exceptions can be handled only in C++ code. The C++ exceptions are
  602. described in the Library Reference, "C++ run-time support." See Chapter 4
  603. of the Programmer's Guide for a full description of how to use exception
  604. handling.
  605.  
  606. Borland C++ 4.0 also implements the accepted ANSI C++ new style casts. See the
  607. Chapter 3 of the Programmer's Guide for information and examples.
  608.  
  609. --------------------------
  610. Libraries and Startup Code
  611. --------------------------
  612. The contents of the LIB directory are described in the online Help.
  613. See the DOS Reference for a description of DOS-only libraries and
  614. start-up code.
  615.  
  616. There are two new functions that provide access to 32-bit operating system
  617. file handles. See online Help for a description of _open_osfhandle and
  618. _get_osfhandle.
  619.  
  620. Member function Type_info::fname() is not available.
  621.  
  622. Several global variables and library functions have been renamed. See the
  623. Library Reference, Chapter 1.
  624.  
  625.  
  626. ----------------------------------
  627. Compiler and Linker Switch Changes
  628. ----------------------------------
  629. See the User's Guide for information on new compiler and linker switches.
  630.  
  631. You may get this 32-bit Linker warning:
  632.     Warning: External symbol <XX> was not qualified with __import in 
  633.        module <YY>
  634. If the symbol <XX> is a function, you can ignore this warning.  If
  635. the symbol <XX> is data, then you must qualify the symbol with __import.
  636.  
  637. BCC32 provides support for the Pentium processor. This support is enabled
  638. by the -5 compiler switch.
  639.  
  640. -----------------------------------------------------------------------
  641. Converting Your Borland C++ Version 3.1 Windows Code to Borland C++ 4.0
  642. -----------------------------------------------------------------------
  643. To get your BC++ 3.1 code to compile and run successfully under Borland C++ 4.0,
  644. you can modify your code to reflect three character types where compiler
  645. errors occur when using the Borland C++ 4.0 RTL includes. Otherwise, you can
  646. use the -K2 compiler option with the RTL includes from BC++ 3.1. This option
  647. provides for only two character types. (Note that -K2, a backward 
  648. compatibility switch, is supported only in the 16-bit compiler.) 
  649. Also, use operator new[]() and delete[]() syntax for class arrays.
  650.  
  651. Note that certain 32-bit to 8-bit conversions allowed by ANSI are flagged 
  652. by BCC32 with "Conversion may lose significant digits in function XXXXX".
  653. You can safely ignore this message if you are doing certain types of 32-bit
  654. to 8-bit casts (for instance, int to char) and you're not worried about
  655. losing significant digits in those cases.
  656.  
  657.  
  658. ------------------------------
  659. Changes to the Class Libraries
  660. ------------------------------
  661. Only the version of the class library implemented with C++ templates 
  662. is distributed and directly supported in Borland C++ 4.0.
  663.  
  664. The class library "object-based" include files are provided in the
  665. \BC4\INCLUDE\CLASSLIB\OBSOLETE subdirectory.  The object-based
  666. libraries themselves are not supplied, but can be built using the
  667. instructions found in the \BC4\SOURCE\CLASSLIB makefile (see the
  668. comments located there).
  669.  
  670. TSArray and TSArrayIterator classes have been added to the class libraries.
  671. They are aliases for TSArrayAsVector and TSArrayAsVectorIterator.
  672.  
  673. The Flush and Delete member functions for direct containers (except
  674. dictionaries) no longer take a delete parameter (this parameter had been
  675. ignored since direct containers have their own copy of the contained element).
  676. For example:
  677.  
  678.   TMArrayAsVector<double> arr(10);
  679.   arr.Flush();    // legal
  680.   arr.Flush(1);    // illegal - causes syntax error
  681.   arr.Detach(index);    // legal
  682.   arr.Detach(index,1);    // illegal - causes syntax error
  683.  
  684.   TMIArrayAsVector<double> arr1(10);
  685.   arr1.Flush();    // legal
  686.   arr1.Flush(1);    // legal.
  687.   arr1.Detach(index); // legal
  688.   arr1.Detach(index,1); // legal
  689.  
  690. Bag and set container member function FindMember is now called Find.
  691. It takes the same parameters.
  692.  
  693. Association containers now have a member function called DeleteElements:
  694.  
  695.   void DeleteElements()
  696.  
  697. The dictionary containing the associations determines whether pointed-to
  698. objects should be deleted, and, if so, calls DeleteElements for each of
  699. the associations it holds. The Detach and Flush member functions for the
  700. TMDictionaryAsHashTable template (and all templates derived from it)
  701. have been changed to the following:
  702.  
  703.   int Detach( const T &t, DeleteType dt = DefDelete )
  704.  
  705.   void Flush( DeleteType dt = DefDelete )
  706.  
  707. These changes to the direct versions of the dictionary templates makes them
  708. similar to an indirect container in how they handle object ownership. Here is
  709. an example:
  710.  
  711.   TDIAssociation<int,int> assoc( 3, new int(4) ); //create an association
  712.   TDictionaryAsHashTable<int,int> dict; //creates a dictionary
  713.   dict.Add( assoc ); //copies assoc into the dictionary
  714.   dict.OwnsElements(); //tell dict that it should delete pointed-to objects
  715.   dict.Flush(); //deletes the int created by new in the first line.
  716.  
  717. All list and double-list containers now have the DetachAtHead member function.
  718. This function removes items from the head of a list without searching for a
  719. match. The syntax is
  720.  
  721.   int DetachAtHead() // for direct lists
  722.  
  723.   int DetachAtHead( int del = 0 ) //for indirect lists
  724.  
  725. Example:
  726.  
  727.   TMListImp<MyObject>list; //create list to hold MyObjects
  728.   list.Add(MyObject()); //construct a MyObject, add to list
  729.   list.Add(MyObject()); //add second MyObject
  730.   list.DetachAtHead(); //remove MyObject at head of list
  731.  
  732. Changes to class diagnostics
  733. ----------------------------
  734. Previously, in order to create a diagnostic group you had to declare it
  735. and define it in the same file:
  736.  
  737.   DIAG_DECLARE_GROUP( Sample );
  738.   DIAG_DEFINE_GROUP( Sample, 1, 0 );
  739.  
  740. We also provided a macro that did both of these together:
  741.  
  742.   DIAG_CREATE_GROUP( Sample, 1, 0 );
  743.  
  744. A change in the diagnostic software makes it illegal to have both
  745. DECLARE and DEFINE in the same file. So code that creates a diagnostic
  746. group now does it in one step:
  747.  
  748.   DIAG_DEFINE_GROUP( Sample, 1, 0 );
  749.  
  750. DIAG_CREATE_GROUP has been removed. DIAG_DECLARE_GROUP still creates an
  751. extern declaration for a diagnostic group (see file CHECKS.H and CHECKS.CPP).
  752.  
  753. Code that uses both DIAG_DECLARE_GROUP and DIAG_DEFINE_GROUP in the same
  754. file must be changed to remove DIAG_DECLARE_GROUP.
  755.  
  756. Old code:
  757.  
  758.   DIAG_DECLARE_GROUP( Sample );
  759.   DIAG_DEFINE_GROUP( Sample, 1, 0 );
  760.  
  761. New code:
  762.  
  763.   DIAG_DEFINE_GROUP( Sample, 1, 0 );
  764.  
  765. Any use of DIAG_CREATE_GROUP must be changed to DIAG_DEFINE_GROUP.
  766.  
  767. Old code:
  768.   DIAG_CREATE_GROUP( Sample, 1, 0);
  769.  
  770. New code:
  771.  
  772.   DIAG_DEFINE_GROUP( Sample, 1, 0 );
  773.  
  774. Also if a header file uses DIAG_DECLARE_GROUP (so that the group declaration is
  775. automatically available to files that #include the header), the source file
  776. that contains the DIAG_DEFINE_GROUP invocation for that group will generate
  777. a redefinition error (this isn't done anywhere in OWL or class lib). The
  778. solution here to conditionalize the header file so that the declaration goes
  779. away when the source file with the DIAG_DEFINE_GROUP invocation is built:
  780.  
  781.     foo.h
  782.     -------
  783.     #if !defined( BUILD_FOO_GROUP )
  784.     DIAG_DECLARE_GROUP( Foo );
  785.     #endif
  786.  
  787.     foo.cpp
  788.     -----------
  789.     #define BUILD_FOO_GROUP
  790.     #include "foo.h"
  791.  
  792.  
  793. Changes to Object Streaming
  794. ---------------------------
  795. The implementation of Object Streaming formerly used in ObjectWindows and
  796. Turbo Vision has been moved into the class library. There have been several
  797. changes made to the streaming mechanism, but they should be transparent to
  798. existing class library code.  See the Programmer's Guide for details on 
  799. streaming.
  800.  
  801. The header file OBJSTRM.H defines several macros that will make creating
  802. streamable objects easier. See that header file for further documentation.
  803.  
  804. There are two types of streamable objects:
  805.  - Resident objects which may be streamed out but which are not reconstructed
  806.    when streamed back in
  807.  - Dynamic objects which are reconstructed when streamed in.
  808.  
  809. Resident objects include static objects and objects present when an
  810. application starts, such as its main window. These objects must be streamed
  811. out via a reference rather than via a pointer.
  812.  
  813. Dynamic objects, on the other hand, must be streamed out via pointers,
  814. causing them to be reconstructed when streamed back in.
  815.  
  816. Resident objects must be streamed out before any objects which stream out
  817. pointers to the resident objects, else duplicate objects will be constructed
  818. when streaming in.
  819.  
  820. When streaming objects in, Streamer::Read must insure that all data fields
  821. are initialized, because the streaming constructor doesn't initialize any of
  822. the data fields. Any data members not streamed in must be set to meaningful
  823. values. Care must be taken to initialize the members before streaming in base
  824. class data or pointers to objects which have pointers back to the current
  825. object. Virtual functions are enabled in Streamer::Read.
  826.  
  827. Changes to the string class
  828. ---------------------------
  829. The following sections correct string class member function definitions.
  830.  
  831.   size_t find_first_of( const string _FAR &s ) const
  832. Locates the first occurrence in the target string of any character contained
  833. in string s. If the search is successful find_first_of returns the character
  834. location. If the search fails it returns NPOS.
  835.  
  836.   size_t find_first_of( const string _FAR &s, size_t pos ) const
  837. Locates the first occurrence in the target string of any character contained
  838. in string s after position pos. If the search is successful, it returns the
  839. character position within the target string. If the search fails or if
  840. pos > length(), it returns NPOS.
  841.  
  842.   size_t find_first_not_of( const string _FAR &s) const
  843. Locates the first occurrence in the target string of any character not
  844. contained in string s. If the search is successful, find_first_not_of returns
  845. the character position within the target string. If the search fails it
  846. returns NPOS.
  847.  
  848.   size_t find_first_not_of( const string _FAR &s, size_t pos ) const
  849. Locates the first occurrence in the target string of any character not
  850. contained in string s after position pos. If the search is successful
  851. find_first_not_of returns the character position within the target string.
  852. If the search fails or if pos > length(), find_first_not_of returns NPOS.
  853.  
  854.   size_t find_last_of( const string _FAR &s ) const
  855. Locates the last occurrence in the target string of any character contained in
  856. string s. If the search is successful find_last_of returns the character
  857. position within the target string. If the search fails it returns 0.
  858.  
  859.   size_t find_last_of( const string _FAR &s, size_t pos ) const
  860. Locates the last occurrence in the target string of any character contained in
  861. string s after position pos. If the search is successful find_last_of returns
  862. the character position within the target string. If the search fails or if
  863. pos > length(), find_last_of returns NPOS.
  864.  
  865.   size_t find_last_not_of( const string _FAR &s ) const
  866. Locates the last occurrence in the target string of any character not
  867. contained in string s. If the search is successful find_last_not_of returns
  868. the character position within the target string. If the search fails it
  869. returns NPOS.
  870.  
  871.   size_t find_last_not_of( const string _FAR &s, size_t pos ) const
  872. Locates the last occurrence in the target string of any character not
  873. contained in string s after position pos. If the search is successful
  874. find_last_not_of returns the character position within the target string. If
  875. the search fails or if pos > length(), find_last_not_of returns NPOS.
  876.  
  877. The assign member funtion
  878.  
  879.     assign( const string&, size_t = NPOS );
  880.  
  881. was changed to
  882.  
  883.     assign( const string&, size_t = 0, size_t = NPOS );
  884.  
  885. The size_t parameter in the old version was the number of characters
  886. to copy. In the new version that is the second size_t parameter; the
  887. first one is the position in the passed string to start copying.
  888. For example:
  889.  
  890.     string s1 = "abcdef";
  891.     string s2;
  892.     s2.assign( s1, 2, 3 );
  893.  
  894. After executing this code, s2 should contain "cde".
  895.  
  896. The same change was made in several other functions. The following lists the
  897. new form:
  898.  
  899.     string( const string _FAR &, size_t, size_t );
  900.     string( const char _FAR *, size_t, size_t );
  901.     string( const char __far *, size_t, size_t );
  902.     assign( const string _FAR &, size_t, size_t );
  903.     append( const string _FAR &, size_t, size_t );
  904.     append( const char _FAR *, size_t, size_t );
  905.     prepend( const string _FAR&, size_t, size_t );
  906.     prepend( const char _FAR*, size_t, size_t );
  907.     compare( const string _FAR&, size_t, size_t );
  908.     insert( size_t, const string _FAR&, size_t, size_t );
  909.     replace( size_t, size_t, const string _FAR&, size_t, size_t );
  910.  
  911.  
  912. --------------
  913. Casting Macros
  914. --------------
  915. The following casting macros have been provided, and are defined in
  916. \BC4\INCLUDE\CLASSLIB\DEFS.H:
  917.  
  918.   TYPESAFE_DOWNCAST(object,toClass)
  919. Converts the pointer referred to by 'object' into a pointer to an object of
  920. type 'toClass'. Note that the macro parameters to TYPESAFE_DOWNCAST are in the
  921. opposite order from the rest of the macros here. When using a compiler that
  922. supports new style casts and runtime type information this is done with
  923. dynamic_cast<> and will return 0 if the cast cannot be done. When using a
  924. compiler that does not support new-style casts and runtime type information
  925. this is done with fake runtime type information generated by the
  926. IMPLEMENT_CASTABLE macro.
  927.  
  928.   STATIC_CAST(targetType,object)
  929. Converts the data object referred to by 'object' into the type referred to
  930. by 'targetType'. When using a compiler that supports new style casts, this is
  931. done with static_cast<> and will fail if the cast cannot be done without
  932. runtime type information. When using a compiler that does not support new-style
  933. casts, this is done with an old-style dangerous cast.
  934.  
  935.   CONST_CAST(targetType,object)
  936. Converts the data object referred to by 'object' into the type referred to
  937. by 'targetType'. When using a compiler that supports new style casts, this
  938. is done with const_cast<> and will fail if the cast changes the type of the 
  939. object in any way other than adding or removing const and volatile qualifiers.
  940. When using a compiler that does not support new-style casts, this is done with
  941. an old-style dangerous cast.
  942.  
  943.   REINTERPRET_CAST(targetType,object)
  944. Converts the data object referred to by 'object' into the type referred to
  945. by 'targetType'. When using a compiler that supports new style casts, this
  946. is done with reinterpret_cast<>. When using a compiler that does not support
  947. new-style casts, this is done with an old-style dangerous cast.
  948.  
  949. ------------------------
  950. IDE/Integrated Debugging
  951. ------------------------
  952. Using the IDE under NT is not currently supported.
  953.  
  954. The default extension for Borland C++ 4.0 project files is IDE. 
  955.  
  956. Using the Microsoft DBWIN utility interferes with the Event log's
  957. ability to display those same messages. If you wish to see those messages in
  958. the Event log, either quit DBWIN or select Options|No Output in DBWIN.
  959.  
  960. Project style sheets are inherited from the default project when you select
  961. Project|New. You can set inheritance using the following option in the BCW.INI
  962. file:
  963.    [projects]
  964.    inherit=0
  965. where 0 inherits from the default project, 1 from the previous project,
  966. and 2 from the shipping defaults (which are unchangeable).
  967.  
  968. The following listing explains some of the more useful BCW.INI settings:
  969.  
  970. [ToolDir]                ; BCW's default paths
  971. BcInclude=\bc4\include   ;Default Include path, MPD Directories
  972. BcLib=\bc4\lib           ;Default Lib path, MPD Directories
  973.  
  974. [Project]
  975. saveastext=1    ;PDL file with Style Sheets and Modified tools
  976. readastext=1    ;Read Style Sheets and Tools
  977.  
  978. [IDE]
  979. HelpDir=C:\BC4\BIN              ;where to find the help files
  980. DefaultDesktopDir=C:\BC4\BIN\   ;where to find bcconfig.bcw,
  981.                                 ;bcwdef.bcw/dsw,*.tok,*.ckb
  982.  
  983.  
  984. If you step over or into a throw() call, the application will run until it
  985. reaches a breakpoint or program termination, instead of stopping at the
  986. appropriate catch() function. If you wish to debug catch() functions, you
  987. must set breakpoints within them.
  988.  
  989. Run to Cursor (F4) will do nothing if the source line you wish to run to is
  990. the same source line that the execution point is on. Thus, using F4 to iterate
  991. through any loop structure will not work. Instead, set a breakpoint on a line
  992. in the loop and use Ctrl-F9 (Debug|Run) to iterate through the loop. Once
  993. finished with the loop, the breakpoint can be removed.
  994.  
  995. The following combination of events will cause unusual behavior:
  996.  
  997.   - Placing breakpoints in Windows procedures or OWL event handler which will
  998.     receive WM_KILLFOCUS or WM_WINDOWPOSCHANGED messages.
  999.   - Shifting focus from this application while debugging, directly to the IDE.
  1000.  
  1001. When focus is changed from the application being debugged to the IDE, Windows
  1002. initiates an intertask SendMessage from the IDE to the application. But the
  1003. breakpoint prevents SendMessage from completing, putting Windows into an
  1004. unstable state. Many GUI debuggers silently ignore a breakpoint in this
  1005. situation. The Borland Integrated Debugger displays a message box warning of
  1006. this situation giving you the choice of ignoring the breakpoint and continuing
  1007. the application, or aborting the application so you can make further changes to
  1008. the code or placement of breakpoints before running again. The best way to
  1009. avoid this situation is to not click on the IDE when you have a breakpoint in
  1010. the Window procecure or OWL event handler that could stop due to an intertask
  1011. SendMessage from the IDE. Instead click on some other application like the
  1012. Program Manager. This will still result in the WM_KILLFOCUS and related
  1013. messages and the intertask SendMessage, but the initiating task will not be the
  1014. IDE and thus completely avoids the Windows instability.
  1015.  
  1016. One further note: the first click of the mouse on the IDE immediately initiates
  1017. the MessageBox and the click in the OK box is the next mouse event captured, so
  1018. interesting visual effects may occur depending on where that first mouse click
  1019. occurred. For example, if the first click was in the title bar of the IDE, the
  1020. second click (in the MessageBox OK) will result in a move of the IDE Window
  1021. from its original location to the location of the OK mouse click. If this
  1022. happens, move the IDE back to where you want it.
  1023.  
  1024.  
  1025. ----------------------
  1026. Floating Point Formats
  1027. ----------------------
  1028. Floating point formats are a collection of formatting information used to
  1029. manipulate floating point numbers in certain runtime library functions such as
  1030. scanf() and atof().
  1031.  
  1032. This section discusses why you might get the error 
  1033. FLOATING POINT FORMATS NOT LINKED : ABNORMAL PROGRAM TERMINATION and tells
  1034. you how to resolve it.
  1035.  
  1036. There are no current plans to fix this because it is not a bug. The intent
  1037. is to avoid linking the floating point formats (about 1K of overhead) when
  1038. they are not required.  The tradeoff of this feature is that the programmer
  1039. must explicitly request that the floating point formats be linked in for some
  1040. programs that manipulate floats in a limited and specific fashion.
  1041.  
  1042. Because you can get the error in a number of different ways, check the
  1043. following list of potential causes to find out how to resolve the error.
  1044. These are listed in order of most common to least common causes.
  1045.  
  1046.   1.  CAUSE:  Floating point set to <None>.  You have your
  1047.       floating point option set to None when it should be set to
  1048.       either Fast or Normal.
  1049.  
  1050.       FIX:  Set Floating Point to Fast or Normal.  
  1051.  
  1052.   2.  CAUSE:  Either the compiler is overoptimizing, or the
  1053.       floating point formats really do need to be linked in because
  1054.       your program manipulates floats in a limited and specific
  1055.       fashion.  Under certain obscure conditions, the compiler will
  1056.       ignore floating point usage in scanf().  (e.g., trying to
  1057.       read into a float variable that is part of an array contained
  1058.       in a structure.)
  1059.  
  1060.       FIX: Add the following to one source module:
  1061.  
  1062.               extern _floatconvert;
  1063.               #pragma extref _floatconvert
  1064.  
  1065.   3.  CAUSE:  Forgetting to put the address operator & on the scanf
  1066.       variable expression.  For example,
  1067.           float foo;
  1068.           scanf("%f", foo);
  1069.  
  1070.       FIX:  Change the code so that the & operator is used where it
  1071.       is needed.  For example, the above code should be
  1072.           float foo;
  1073.           scanf("%f", &foo);
  1074.  
  1075.  
  1076. --------------------------
  1077. Turbo Debugger for Windows
  1078. --------------------------
  1079. You can use TD32 to debug under Win32s. However, to do so, you must
  1080. ensure you use SVGA.DLL or equivalent support in the VideoDLL entry
  1081. in the [TurboDebugger] section of TDW.INI.
  1082.  
  1083. TD32 can support dual monitor debugging under Win32s. Ensure that
  1084. a monochrome adapter is installed in your machine and set the
  1085. Mono=yes flag in the [VideoOptions] section of TDW.INI:
  1086.  
  1087.     [VideoOptions]
  1088.     MONO=yes
  1089.  
  1090. See the online text file called td_help!.txt for more information on
  1091. using TD32 and TDW.
  1092.  
  1093. ---------------------
  1094. Using Tools with NTFS
  1095. ---------------------
  1096. When using Borland C++ 4.0 tools under NTFS, there are issues to be aware
  1097. of related to extension assumptions. If Borland C++ 4.0 tools see an
  1098. extension, they assume no default.  Therefore, with "bcc32 test.1.cpp",
  1099. BCC32 spawns TLINK32 with "-ap c0x32.obj test.1, test.1, import32 cw32".
  1100. As TLINK32 sees an extension on test.1, it makes NO assumptions about
  1101. a .obj or .exe extension.  It attempts to look for test.1 (instead of
  1102. test.1.obj) and to create test. (instead of test.1.exe).
  1103.  
  1104. Embedded blanks in filenames are not currently supported. For instance, under
  1105. the Windows NT NTFS file system it is legal to have a file named
  1106. "This is an interesting file name.cpp". The response file processing in our
  1107. 32-bit tools cannot handle this type of file.
  1108.  
  1109. 16-bit tools running on NT cannot use NTFS filenames.
  1110.