home *** CD-ROM | disk | FTP | other *** search
/ Liren Large Software Subsidy 7 / 07.iso / c / c185 / 1.ddi / READ.ME < prev   
Encoding:
Text File  |  1989-09-12  |  84.1 KB  |  2,227 lines

  1.  
  2.  
  3.  
  4.  
  5.  
  6.  
  7.  
  8.  
  9.  
  10.  
  11.  
  12.  
  13.  
  14.  
  15.  
  16.  
  17.  
  18.  
  19.  
  20.                               C-scape 3.1 READ ME
  21.  
  22.                     Copyright (c) 1989, Oakland Group, Inc.
  23.  
  24.  
  25.  
  26.  
  27.  
  28.  
  29.  
  30.  
  31.  
  32.  
  33.  
  34.  
  35.  
  36.  
  37.  
  38.  
  39.  
  40.  
  41.  
  42.  
  43.  
  44.  
  45.  
  46.  
  47.  
  48.  
  49.  
  50.  
  51.  
  52.  
  53.  
  54.  
  55.  
  56.  
  57.  
  58.  
  59.  
  60.  
  61.  
  62.  
  63.  
  64.  
  65.  
  66.  
  67.  
  68.                                Table of Contents
  69.  
  70. 1:  INTRODUCTION                                                         1
  71.  
  72. 2:  WHAT YOU SHOULD READ                                                 1
  73.  
  74. 3:  DISK CONTENTS                                                        1
  75.  
  76. 4:  INSTALLATION                                                         2
  77.    4.1:  Quick And Dirty (First Time Installation)                       2
  78.    4.2:  Quick And Dirty (Upgrade)                                       2
  79.    4.3:  Less Quick And Dirty (First Time Installation)                  2
  80.    4.4:  Less Quick And Dirty (Upgrade)                                  3
  81.    4.5:  Notes On Source Code                                            3
  82.  
  83. 5:  COMPILING AND LINKING                                                4
  84.    5.1:  General Information                                             4
  85.    5.2:  Microsoft C 5.0 And 5.1                                         4
  86.       5.2.1:  Microsoft C 5.0 And 5.1 Command Lines                      4
  87.       5.2.2:  Microsoft Quick C Command Lines                            4
  88.       5.2.3:  Microsoft Quick C Integrated Environment                   5
  89.          5.2.3.1:  Microsoft Quick C 2.0 Integrated Environment          5
  90.          5.2.3.2:  Microsoft Quick C 1.0 Integrated Environment          5
  91.                         
  92.       5.2.4:  Microsoft C 5.0 And 5.1 Common Compile And Link Errors     6
  93.                      
  94.    5.3:  Turbo C 2.0                                                     7
  95.       5.3.1:  Turbo C 2.0 Command Line                                   7
  96.       5.3.2:  Turbo C Integrated Environment                             7
  97.  
  98.    5.4:  Turbo C Versions Prior To 2.0                                   8
  99.  
  100. 6:  UPDATES TO THE MANUAL                                                8
  101.    6.1:  Updates To The 3.1 Manual                                       8
  102.    6.2:  Updates To The 3.0 Manual                                       9
  103.    6.3:  Updates To The 3.0 Manual Addendum                              9
  104.  
  105. 7:  ERRATA FOR THE MANUAL                                                9
  106.    7.1:  Errata For The 3.1 Manual                                       9
  107.    7.2:  Errata For The 3.0 Manual                                       12
  108.    7.3:  Errata For The 3.0 Manual Addendum                              13
  109.  
  110. 8:  SAMPLE PROGRAMS                                                      14
  111.    8.1: cscape                                                           14
  112.    8.2: demofm                                                           14
  113.    8.3: demomous                                                         14
  114.    8.4: demofram                                                         14
  115.    8.5: demoslug                                                         14
  116.    8.6: demosled                                                         14
  117.    8.7: demograf                                                         14
  118.    8.8: demopcx                                                          14
  119.    8.9:  demoflod                                                        14
  120.    8.10:  demofsav                                                       14
  121.    8.11: demohelp                                                        15
  122.    8.12: demotty.c                                                       15
  123.  
  124. 9:  WHAT'S BEEN FIXED                                                    15
  125.  
  126. 10:  WHAT'S NEW IN THIS RELEASE                                          15
  127.  
  128. 11:  WHAT'S IMPROVED IN THIS RELEASE                                     16
  129.  
  130. 12:  NEW FUNCTIONS                                                       16
  131.  
  132. 13:  NEW SLED FUNCTIONS                                                  17
  133.  
  134. 14:  CMAP AND PMAP WINDOWS                                               18
  135.  
  136. 15:  OAKLAND DEBUGGING AID                                               21
  137.  
  138. 16:  A FEW OAKLAND CODE CONVENTIONS                                      22
  139.    16.1:  OGLOBAL                                                        22
  140.    16.2:  OEXTERN                                                        22
  141.    16.3:  FNULL                                                          22
  142.  
  143. 17:  RECOMPILING THE SOURCE CODE                                         23
  144.    17.1:  General                                                        23
  145.    17.2:  Microsoft C Make                                               24
  146.       17.2.1:  OWL                                                       24
  147.       17.2.2:  CSCAPE                                                    24
  148.  
  149.    17.3:  Turbo-C 2.0 Make                                               24
  150.       17.3.1:  OWL                                                       24
  151.       17.3.2:  CSCAPE                                                    25
  152.  
  153.    17.4:  Opus Make 5.0                                                  25
  154.  
  155. 18:  OS/2                                                                25
  156.  
  157. 19:  OAKLAND TECHNICAL SUPPORT                                           26
  158.  
  159. 20:  WHAT IS COMING FROM OAKLAND                                         26
  160.  
  161.  
  162.  
  163. _______________________________________________________________________________
  164.  
  165. 1:  INTRODUCTION
  166.  
  167.     Thank you for purchasing C-scape 3.1!
  168.  
  169.     Please complete and return your registration card so we can send you the
  170.     library source.  The registration card also serves to allow us to send you
  171.     information of new versions and features.  We automatically notify
  172.     registered users of new versions and new products.
  173.  
  174.     New C-scape users and those current users who are upgrading from 2.0 should
  175.     have received the following:
  176.  
  177.         2 disks (an additional source disk is sent upon receipt of
  178.     registration)
  179.         2 manuals (the C-scape Manual and the C-scape Function Reference)
  180.  
  181.     Current users who are upgrading from version 3.0 or 3.0a should have
  182.     received the following:
  183.  
  184.         2 disks (an additional source disk is sent upon receipt of
  185.     registration)
  186.         1 addendum (the C-scape Manual Addendum)
  187.  
  188.  
  189.  
  190.  
  191. _______________________________________________________________________________
  192.  
  193. 2:  WHAT YOU SHOULD READ
  194.  
  195.     THIS FILE DOCUMENT CONTAINS INFORMATION ESSENTIAL TO USING C-SCAPE.  AT A
  196.     MINIMUM, YOU SHOULD READ THE FOLLOWING SECTIONS OF THIS DOCUMENT:
  197.  
  198.              DISK CONTENTS
  199.              INSTALLATION
  200.              COMPILING AND LINKING
  201.              MANUAL UPDATES
  202.              MANUAL ERRATA
  203.  
  204.     In addition we recommend that you read the following additional sections:
  205.  
  206.              OAKLAND DEBUGGING AID
  207.              OAKLAND CODE CONVENTIONS
  208.  
  209.     If you are upgrading to C-scape 3.1 from 3.0 or 3.0a, you should read the
  210.     following additional sections of this document.
  211.  
  212.              WHAT'S BEEN FIXED
  213.              WHAT'S NEW IN THIS RELEASE
  214.              WHAT'S IMPROVED IN THIS RELEASE
  215.              NEW FUNCTIONS (SLEDS)
  216.              NEW FUNCTIONS (PCX FILE SUPPORT)
  217.              OAKLAND DEBUGGING AID
  218.  
  219.  
  220.  
  221.  
  222. _______________________________________________________________________________
  223.  
  224. 3:  DISK CONTENTS
  225.  
  226.     The distribution disks are high-density DOS format floppies.
  227.  
  228.     All files on the C-scape distribution disks with the .EXE filename
  229.     extension are self-extracting archives.
  230.  
  231.     In the following list, disk numbers followed with an M refer to the
  232.     Microsoft version, T refers to Turbo-C version.
  233.  
  234.     TDisk    READ.ME              This file
  235.     1        CSHEAD.EXE           C-scape header files
  236.              OWLHEAD.EXE          Oakland Windowing Library (OWL) header files
  237.              FUNCS.EXE            Source for field functions
  238.              EXAMPLE.EXE          C-scape examples and Demos
  239.              INSTALL.BAT          Installation batch file
  240.              T2LOWL.EXE           Large memory model Turbo-C OWL library
  241.              T2LCSCAP.EXE         Large memory model Turbo-C C-scape library
  242.              T2MOWL.EXE           Medium memory model Turbo-C OWL library
  243.              T2MCSCAP.EXE         Medium memory model Turbo-C C-scape library
  244.              INSTALL.BAT          Installation batch file
  245.  
  246.     MDisk    READ.ME              This file
  247.     1        CSHEAD.EXE           C-scape header files
  248.              OWLHEAD.EXE          Oakland Windowing Library (OWL) header files
  249.              FUNCS.EXE            Source for field functions
  250.              EXAMPLE.EXE          C-scape examples and Demos
  251.              M1LOWL.EXE           Large memory model Microsoft OWL library
  252.              M1LCSCAP.EXE         Large memory model Microsoft C-scape library
  253.              M1MOWL.EXE           Medium memory model Microsoft OWL library
  254.              M1MCSCAP.EXE         Medium memory model Microsoft C-scape library
  255.              INSTALL.BAT          Installation batch file
  256.  
  257.     Source   CSSRC.EXE            C-scape source code
  258.              OWLSRC.EXE           OWL source code
  259.                                   Source is shipped separately upon receipt of
  260.                                   registration
  261.  
  262.  
  263.  
  264.  
  265. _______________________________________________________________________________
  266.  
  267. 4:  INSTALLATION
  268.  
  269. 4.1:  Quick And Dirty (First Time Installation)
  270.  
  271.     The quick and dirty installation of C-scape is just that, very quick. All
  272.     that is needed is to place the first floppy in the appropriate disk drive,
  273.     change to that disk drive and enter install D:. This will automatically
  274.     create the C-scape directories and copy the files to those directories.
  275.  
  276.     As an example, to install C-scape just off the main directory of a C drive
  277.     from the a: drive,  do the following:
  278.  
  279.     place the floppy in drive a: and enter:
  280.  
  281.     >install c:
  282.  
  283.     and sit back and watch.
  284.  
  285.     This will need to be done with both C-scape diskettes.
  286.  
  287.     The directories created are as follows( This assumes that the installation
  288.     was done off the root directory ).
  289.  
  290.     \cscape\lib                     library (.lib) files
  291.     \cscape\include                 header (.h) files
  292.     \cscape\source                  field function source (.c) files
  293.     \cscape\examples                C-scape example and Demo programs
  294.  
  295. 4.2:  Quick And Dirty (Upgrade)
  296.  
  297.     NOTE
  298.     The quick and dirty installation of a C-scape upgrade is identical to the
  299.     above except that you must ensure that there are no old C-scape headers or
  300.     libs in the directories.
  301.  
  302.     NOTE
  303.     Be sure to recompile ALL of your application source using the new headers
  304.     and libraries. Failure to do so will produce some very strange unresolved
  305.     external errors in the link.
  306.  
  307. 4.3:  Less Quick And Dirty (First Time Installation)
  308.  
  309.     To install C-scape we suggest that you create a C-scape directory on your
  310.     hard disk with the following sub-directories:
  311.  
  312.     \cscape\lib                     library (.lib) files
  313.     \cscape\include                 header (.h) files
  314.     \cscape\source                  field function source (.c) files
  315.     \cscape\examples                C-scape example programs
  316.  
  317.     All files on the C-scape distribution disks with the .EXE filename
  318.     extension are self-extracting archives.  To decompress the archive simply
  319.     enter the name of the archive followed by the drive and directory in which
  320.     you wish to place the files to be extracted.
  321.  
  322.     For example:
  323.  
  324.         FUNCS C:\CSCAPE\SOURCE
  325.  
  326.     would extract the C-scape field function source from FUNCS.EXE and place
  327.     them in the \CSCAPE\SOURCE directory on drive C:.
  328.  
  329.     In order to verify that the archive has not been corrupted ( a fairly
  330.     unlikely event ) you may wish to use the -t switch so that the archive will
  331.     perform a test of its own integrity.
  332.  
  333.         CSHEAD -t
  334.  
  335.     C-scape 3.1 actually consists of two libraries. There is the C-scape
  336.     library and the Oakland Windowing Library (OWL). And, for each of the two
  337.     libraries there is a large memory model and a medium memory model version
  338.     of the library.  There are also two groups of associated header files:
  339.     C-scape headers and OWL headers.
  340.  
  341.     In accordance with the above directory structure, a complete installation
  342.     would involve entering the following:
  343.  
  344.         T2MCSCAP C:\CSCAPE\LIB
  345.         T2LCSCAP C:\CSCAPE\LIB
  346.         T2MOWL C:\CSCAPE\LIB
  347.         T2LOWL C:\CSCAPE\LIB
  348.         CSHEAD C:\CSCAPE\INCLUDE
  349.         OWLHEAD C:\CSCAPE\INCLUDE
  350.     *   CSSRC C:\CSCAPE\SOURCE
  351.     *   OWLSRC C:\CSCAPE\SOURCE
  352.  
  353.     * NOTE that the source diskette that contains these two archives is sent to
  354.     you upon receipt of the registration card
  355.  
  356.     The above would install C-scape 3.1 libraries, header files and source code
  357.     for use with the Borland Turbo-C 2.0 compiler. If you have the Microsoft C
  358.     5.1 compiler then the library medium and large memory model archive names
  359.     would begin with M1M and M1L instead of T2M and T2L.
  360.  
  361.     You must install ALL header files for both C-scape and OWL headers are
  362.     necessary to compiling a C-scape application program.  Likewise, you must
  363.     link with BOTH the C-scape and OWL libraries before running your program.
  364.  
  365.     You do not need the files contained in FUNCS.EXE or EXAMPLE.EXE to use
  366.     C-scape but you may find them useful.
  367.  
  368. 4.4:  Less Quick And Dirty (Upgrade)
  369.  
  370.     NOTE
  371.     The installation of a C-scape upgrade is identical to the above except that
  372.     you must ensure that there are no old C-scape headers or libs in the
  373.     directories.
  374.  
  375.     NOTE
  376.     Be sure to recompile ALL of your application source using the new headers
  377.     and libraries. Failure to do so will produce some very strange unresolved
  378.     external errors in the link.
  379.  
  380. 4.5:  Notes On Source Code
  381.  
  382.     The diskettes you have been shipped include source code for the field
  383.     functions only. These are the functions documented in Appendix B of the
  384.     C-scape Function Reference. These functions are those that programmers find
  385.     it necessary to modify at one time or another.
  386.  
  387.     The source for the rest of the functions in the libraries is sent by
  388.     Oakland upon receipt of your registration card. Note that sending in your
  389.     registration card signals the end of your 30 day trial period and should
  390.     not be done until you have decided to keep the C-scape package.
  391.  
  392.  
  393.  
  394.  
  395. _______________________________________________________________________________
  396.  
  397. 5:  COMPILING AND LINKING
  398.  
  399. 5.1:  General Information
  400.  
  401.     The first three letters of the C-cscape library files indicate the compiler
  402.     and memory model of the library. M1 for Microsoft C 5.1, T2 for Turbo C
  403.     2.0).  Only large and medium memory models of the libraries have been
  404.     provided.  A small model library is not included because the base size of
  405.     an executable with C-scape code exceeds the amount of code allowable in the
  406.     code segment of a small model program.
  407.  
  408.     You must link with BOTH the OWL and C-scape libraries.  You must be sure to
  409.     use the appropriate memory models.
  410.  
  411.     All C-scape's header files must be placed where the compiler can find them.
  412.     Creating a sub-directory \cscape\include is recommended.  To tell the
  413.     compiler the location of the C-scape header files, use either the
  414.     environment variable INCLUDE or a compiler flag.  Consult your compiler
  415.     reference for more information.
  416.  
  417.     Please do not call us with questions about compilers.  Call the compiler
  418.     vendor.
  419.  
  420. 5.2:  Microsoft C 5.0 And 5.1
  421.  
  422. 5.2.1:  Microsoft C 5.0 And 5.1 Command Lines
  423.  
  424.     Medium model compile and link lines:
  425.  
  426.         cl /c /DM5 /AM /I\cscape\include myprog.c
  427.  
  428.         link /SE:500 cscape, cscape, , \cscape\lib\m1mowl \cscape\lib\m1mcscap;
  429.  
  430.     Large model compile and link lines:
  431.  
  432.         cl /c /DM5 /AL /I\cscape\include myprog.c
  433.  
  434.         link /SE:500 cscape, cscape, , \cscape\lib\m1lowl \cscape\lib\m1lcscap;
  435.  
  436.     You must define M5 (not M1) with the /D flag.  This is because some of the
  437.     Oakland header files are compiler specific.  If you do not define this
  438.     symbol you'll get the Microsoft C message "error C2061: syntax error:
  439.     identifier 'byte'".
  440.  
  441.     Note also that your .c source file must have the STDIO.H or STDLIB.H file
  442.     included before the CSCAPE.H file in order for the compiler to use certain
  443.     implementation specific symbols.  If this is not done you will recieve a
  444.     message telling you that SIZE_T is undefined.
  445.  
  446.     You may have to alter the use of /SE: to increase the number of link
  447.     segments.  The above specification of /SE:500 is only a suggestion.  It
  448.     should work with most compilations of application programs.  If you get the
  449.     Microsoft error message "error L1049: too many segments" then you need to
  450.     increase the number of segments specified with the /SE:.  Note that if the
  451.     /SE: switch is not included then the Microsoft Linker defaults to 128.
  452.  
  453.     Do not the packed structures (/Zp) option when compiling.  We have compiled
  454.     C-scape library objects with the default Microsoft compiler setting.  Use
  455.     of the /Zp option to force any other alignment will result in
  456.     incompatibility.  If you need to use packed structures - because you are
  457.     linking with another library that uses them,  for example - you must
  458.     recompile the entire C-scape and OWL libraries with the same structure
  459.     packing as your application. See the section of the READ.ME file
  460.     RECOMPILING THE SOURCE CODE.
  461.  
  462. 5.2.2:  Microsoft Quick C Command Lines
  463.  
  464.     Please refer to the previous section discussing the command lines for the
  465.     Microsoft C 5.0 and 5.1 Optimizing Compiler.  While the Quick C compiler
  466.     does not have all the options the 5.0 and 5.1 compilers offer the command
  467.     lines specified above will work under both.
  468.  
  469. 5.2.3:  Microsoft Quick C Integrated Environment
  470.  
  471. 5.2.3.1:  Microsoft Quick C 2.0 Integrated Environment
  472.  
  473.     To use the Quick C 2.0 integrated environment follow these instructions:
  474.  
  475.      1)  Select "Set Program List" from the "Make" menu.
  476.  
  477.      a)  Type in the name of the .mak file you wish to create in the "File
  478.          Name" field - e.g., "myprog.mak".  Answer "Yes" when you are asked if
  479.          you wish to create a file "myprog.mak".
  480.  
  481.      b)  Type the name of your C program in the "File Name" field.  Example:
  482.          "myprog.c".  Press ENTER and the file name will appear in the "Program
  483.          List" box.
  484.  
  485.      c)  Type in the path and name of the C-scape medium or larger model
  486.          library in the "File Name" field - e.g.,  "\cscape\lib\m1lcscap.lib".
  487.          Press ENTER and "m1lcscap.lib will appear in the "Program List" box.
  488.  
  489.      d)  Type in the path and name of the OWL large or medium model library in
  490.          the "File Name" field - e.g., "\cscape\lib\m1lowl.lib".  Press ENTER
  491.          and "m1lowl.lib" will appear in the Program List box.
  492.  
  493.      e)  Your list should now look like this:
  494.  
  495.              myprog.c
  496.              m1lcscap.lib
  497.              m1lowl.lib
  498.  
  499.      f)  Select the "Save List" option.
  500.  
  501.      2)  Select the "Make" option from the "Options" menu.
  502.  
  503.      a)  Select "Compiler Flags".  Set the memory model for the compilation
  504.          and, in the "Defines" field, enter "M5".  Select "Ok".
  505.  
  506.      b)  From the Build Flags screen, select "Ok".
  507.  
  508.      3)  Select the "Environment" option from the "Options" menu.
  509.  
  510.      a) In the "Include files directories" field, type the directory path of
  511.          your header files - e.g., ".\, \qc\include\, \cscape\include\".
  512.  
  513.      b) In the "Library file directories" field, type the directory path of the
  514.          library files - e.g., "., \qc\lib\, \cscape\lib\".
  515.  
  516.      c) Select "Ok".
  517.  
  518.      4)  Select "Exit" from the "File" menu and reply "Yes" when your are asked
  519.          if you wish to save the changes to your program make file.
  520.  
  521.      5)  Re-enter Quick C and edit your program make file.  To the macro
  522.          definition of "LFLAGS_D" append "/SE:" (follow the ":" with the number
  523.          of segments you want the linker to use).  Save your make file. (Note:
  524.          if we had edited the make file, and saved it before exiting in step 4,
  525.          the "/SE:" change would have been overridden by Quick C's update).
  526.  
  527.      6)  You may now build you program by selecting "Build" from the "Make"
  528.          menu.
  529.  
  530.      7)  Consult the Quick C Programmer's Guide for more information about
  531.          using the integrated environment.
  532.  
  533. 5.2.3.2:  Microsoft Quick C 1.0 Integrated Environment
  534.  
  535.     To use the Quick C 1.0 integrated environment follow these instructions:
  536.  
  537.      1)  Select "Set Program List..." from the "File" menu.
  538.  
  539.      a)  Type in the name of the .mak file you wish to create in the "File
  540.          Name" field - e.g., "myprog.mak".  Answer "Yes" when you are asked if
  541.          you wish to create a file "myprog.mak".
  542.  
  543.      b)  Type the name of your C program in the "File Name" field.  Example:
  544.          "myprog.c".  Press ENTER and the file name will appear in the "Program
  545.          List" box.
  546.  
  547.      c)  Type in the path and name of the C-scape medium model library in the
  548.          "File Name" field - e.g.,  "\cscape\lib\m1mcscap.lib".  Press ENTER
  549.          and "m1mcscap.lib will appear in the "Program List" box.
  550.  
  551.      d)  Type in the path and name of the OWL medium model library in the "File
  552.          Name" field - e.g., "\cscape\lib\m1mowl.lib".  Press ENTER and
  553.          "m1mowl.lib" will appear in the Program List box.
  554.  
  555.      e)  PLEASE NOTE THAT THE QUICK-C 1.0 INTEGRATED ENVIRONMENT ONLY SUPPORTS
  556.          THE MEDIUM MEMORY MODEL.
  557.  
  558.      f)  Your list should now look like this:
  559.  
  560.              myprog.c
  561.              m1mcscap.lib
  562.              m1mowl.lib
  563.  
  564.      g)  Select the "Save" option.
  565.  
  566.      3)  We need to edit the makefile.
  567.  
  568.      a)  Go to the "File" menu and "Open" the your program's make file - e.g.,
  569.          "myprog.mak".
  570.  
  571.      b)  You note that at the end of the make file there is a reference to
  572.          "$(LDFLAGS)" on the link line.   Define this at the top of the make
  573.          file so that the "/SE:" switch is used.  This switch sets the number
  574.          of segments that the linker can use - the default is 128 (too low for
  575.          C-scape library usage) and the ceiling is 3072.  400 or 500 should be
  576.          sufficient for most programs so,  define "LDFLAGS" - e.g.,
  577.          "LDFLAGS=/SE:500".
  578.  
  579.      c)  Save the changes you've made to your makefile.
  580.  
  581.      d)  Exit Quick-C.  You must do this so that you can pull in the updated
  582.          make  file for use.  Had you simply re-opened your program source and
  583.          tried to compile it would not know about the "LDFLAGS" definition yet.
  584.  
  585.      4)  Re-start Quick-C and open your program source file.
  586.  
  587.      5)  Select the "Compile..." Option from the "Run" menu.
  588.  
  589.      a)  In the "Include:" field, type the directory path of your header files
  590.          - e.g., "., \owl\include\, \cscape\include\".
  591.  
  592.      b)  In the "Define:" field, enter "M5".
  593.  
  594.      c)  Go ahead and select the compilation action - i.e, "Build Program",
  595.          "Compile", or "Rebuild All".  If you select "Cancel" the "Include:"
  596.          and "Define:" field contents are not going to be added to your make
  597.          and you'll have to re-edit these fields should you exit and come back
  598.          later.
  599.  
  600.      6)  Select "Exit" from the "File" menu and reply "Yes" when your are asked
  601.          if you wish to save the changes to your program make file.
  602.  
  603.      7)  Consult the Quick C Programmer's Guide for more information about
  604.          using the integrated environment.
  605.  
  606. 5.2.4:  Microsoft C 5.0 And 5.1 Common Compile And Link Errors
  607.  
  608.      C1027: DGROUP data allocation exceeds 64K
  609.  
  610.          Your program is running out of static data space.  Experiment with the
  611.          /Gt compile flag.  This tells the compiler not to place all static
  612.          data (such as menu_Printf format strings) within the same data
  613.          segment.  See the Microsoft User's Guide, p.247, for more information.
  614.  
  615.      C2061: syntax error: identifier "byte"
  616.  
  617.          You must define M5 with the /D flag.  This is because some of the
  618.          Oakland header files are compiler specific.
  619.  
  620.      C2061: syntax error: identifier "SIZE T"
  621.  
  622.          In your source code place the #include <stdio.h> or #include
  623.          <stdlib.h> statement before the #include "cscape.h" statement.
  624.  
  625.      L1049: too many segments
  626.  
  627.          Use the /SE: option to increase the number of link segments (128 is
  628.          the Microsoft LINK default value).
  629.  
  630.      L1101: invalid object module
  631.  
  632.          It can be caused by having an older version of the LINK command
  633.          somewhere on your DOS path.  The other possibility is that the library
  634.          or one of the code modules has been corrupted.
  635.  
  636.      L2003: intersegment self-relative fixup
  637.  
  638.          This can be caused by compiler and library memory model mismatch.
  639.          You've probably compiled under the medium model C library and are
  640.          linking to a the large model C-scape libraries; or, compile under
  641.          large model and are linking to the C-scape medium libraries.  Note
  642.          that there are no small model C-scape libraries.
  643.  
  644. 5.3:  Turbo C 2.0
  645.  
  646. 5.3.1:  Turbo C 2.0 Command Line
  647.  
  648.     Medium model:
  649.  
  650.     tcc -c -mm -I\cscape\include myprog
  651.  
  652.     tlink \tc\lib\c0m myprog, myprog, , \tc\lib\emu \tc\lib\mathm \tc\lib\cm
  653.     \cscape\lib\t2mowl \cscape\lib\t2mcscap
  654.  
  655.     Large model:
  656.  
  657.     tcc -c -ml -I\cscape\include myprog
  658.  
  659.     tlink \tc\lib\c0l myprog, myprog, , \tc\lib\emu \tc\lib\mathl \tc\lib\cl
  660.     \cscape\lib\t2lowl.lib \cscape\lib\t2lcscap
  661.  
  662.     Do not use the word alignment (-a) option when compiling.  We have compiled
  663.     C-scape library objects with the default Turbo C setting.  Use of the -a
  664.     option to force any other alignment will result in incompatibility.  If you
  665.     need to use word alignment - because you are linking with another library
  666.     that uses them,  for example - you must recompile the entire C-scape and
  667.     OWL libraries with the same alignment as your application.
  668.  
  669. 5.3.2:  Turbo C Integrated Environment
  670.  
  671.     To use the Turbo C integrated environment follow these instructions:
  672.  
  673.      1)  Select Options/Environment from the main menu.  Select Directories.
  674.  
  675.      a) Make sure the include directories option lists the path to the
  676.          directory containing the C-scape include (.h) files.
  677.          Example:   \tc\include;\cscape\include;
  678.  
  679.      b) Make sure the libraries directories option list the path to the
  680.          directories containing the C-scape library (.lib) files.
  681.          Example:  \tc\lib;\cscape\lib;
  682.  
  683.      3)  Create a project (.prj) file by opening a new file  (consult the
  684.          Turbo-C manual for more information about project files).
  685.  
  686.      4)  In the project file, list the names of the .C file(s) you are working
  687.          on.  (There should be one file name per line.)  Next, add the C-scape
  688.          library with which you wish to link (make sure you choose the correct
  689.          memory model).
  690.  
  691.              Example:
  692.              --------
  693.              sample.c
  694.              t2lowl.lib
  695.              t2lcscap.lib
  696.  
  697.      5)  Save the project file.
  698.  
  699.      6)  Use the Project menu to set the project name to the file just created.
  700.  
  701.      7)  Now use the compile menu to compile (or build) your program.
  702.  
  703.      8)  Consult the Turbo C Manual for more information about the integrated
  704.          environment.
  705.  
  706. 5.4:  Turbo C Versions Prior To 2.0
  707.  
  708.     The objects created by the compiler of versions of Turbo C prior to 2.0 are
  709.     incompatible with those of Turbo C 2.0.  C-scape is compiled under Turbo C
  710.     2.0. If you are using an older version of Turbo C you must recompile the
  711.     C-scape source.
  712.  
  713.     When recompiling for Turbo-C C 1.5 you will have to place a -DTC on the
  714.     command line because the C-scape and OWL code depends on a pre-defined
  715.     macro define __TURBO_C__ not found in the 1.5 compiler.
  716.  
  717.  
  718.  
  719.  
  720. _______________________________________________________________________________
  721.  
  722. 6:  UPDATES TO THE MANUAL
  723.  
  724. 6.1:  Updates To The 3.1 Manual
  725.  
  726.      -   Please see the New Sled Functions section of this document.
  727.  
  728.      -   There is no built in mouse support for the slug menuing system.
  729.  
  730.      -   Screen files now require that you include object class functions in
  731.          the fsyminit_struct symbol table.  If you use seds, sleds and user
  732.          functions then you must add the following entries to your symbol
  733.          table:
  734.  
  735.              { FSYM_CLASS },
  736.              { "sedwin_Class",   (VOID_FPTR)sedwin_Class,    NULL },
  737.              { "sledwin_Class,   (VOID_FPTR)sledwin_Class,   NULL }.
  738.              { "ufunc_Class",    (VOID_FPTR)ufunc_Class,     NULL },
  739.  
  740.          Always include the entry of the delimiter "{ FSYM_CLASS }".  If you are
  741.          using seds you need the sedwin_Class entry.  If you are using sleds
  742.          then include the sledwin_Class entry.  If you are using slugs or
  743.          framers include the ufunc_Class entry.
  744.  
  745.          If you purchased Look & Feel, Look & Feel will automatically generate
  746.          the fsyminit_struct symbol table for your screens and include the
  747.          above classes as appropriate.
  748.  
  749.      -   For code portability you should use FNULL as the second member of a
  750.          fsysminit_struct, instead of NULL, if you need to specify a null
  751.          function pointer.  A null third member, the data pointer, may be
  752.          specified with NULL.  This is to insure compatibility with compilers
  753.          that differentiate between data and function pointers.
  754.  
  755.      -   ted_funcs use the sed generic data pointer for the cut buffer.  If the
  756.          pointer is null at the time the cut buffer is to be first used then
  757.          ted_fkey allocates the buffer and sets the sed data pointer to point
  758.          to it.  This would be the case if you had not explicitly set the sed's
  759.          data pointer by calling sed_SetData.   If the pointer is not null, but
  760.          points to your data, ted_fkey assumes the buffer has been allocated
  761.          and will use that pointer as if it indicated the cut buffer.  If you
  762.          wish to alter this behavior then change ted_fkey in FNTED.C.
  763.  
  764.      -   The field functions char_funcs and hex_funcs do not make use of
  765.          validation.
  766.  
  767.      -   The valid_String() command code prefix {n}, for limiting the
  768.          validation to the first n characters of the string, is valid for
  769.          values of 0 through 9.  A new command {s}, tells string validation to
  770.          ignore ALL whitespace when making it's comparisons.  Example:
  771.          "{s}Hello" would validate "H e ll o ".
  772.  
  773.      The following functions no longer exist:
  774.  
  775.      -   sed_Clear
  776.  
  777. 6.2:  Updates To The 3.0 Manual
  778.  
  779.      -   Please see the C-scape Manual Addendum.
  780.  
  781.      -   Please see the New sled functions section of this document.
  782.  
  783.      -   The integer values in the slug and framer menu definition structure
  784.          should be positive and NON-ZERO (i.e., > 0).
  785.  
  786.      -   There is no built in mouse support for the slug menuing system.
  787.  
  788.      -   The border bd_exp no longer exists.  You can get the same results by
  789.          using:
  790.  
  791.          sed_SetBorder(sed, bd_1);
  792.          sed_SetExplode(sed, exp_std);
  793.  
  794.      -   Embedded seds must use spc_Embed to operate properly.
  795.  
  796.      -   The inner workings of sleds differ from their description in the
  797.          manual (section 10.3.1).  Namely, spc_Sled does all of the work of
  798.          maintaining the sled.  The parent sed's field function, sled_funcs,
  799.          does no sled work.  In fact sled_funcs has been defined to be
  800.          bob_funcs.  Because of these changes, sleds can also operate without
  801.          being embedded.  After opening the sled with sled_Open, simply call
  802.          sled_Repaint and sled_Go.  Refer to the source file spcsled.c for more
  803.          information.
  804.  
  805.      -   The field functions char_funcs and hex_funcs do not make use of
  806.          validation.
  807.  
  808.      -   Field formatting has a new command, c.  This command removes ALL
  809.          whitespace form the field's record.
  810.  
  811.      -   the valid_String() command code prefix {n}, for limiting the
  812.          validation to the first n characters of the string, is valid for
  813.          values of 0 through 9.  A new command {s}, tells string validation to
  814.          ignore ALL whitespace when making it's comparisons.  Example:
  815.          "{s}Hello" would validate "H e ll o ".
  816.  
  817.      The following functions no longer exist:
  818.  
  819.      -   sed_Clear
  820.  
  821. 6.3:  Updates To The 3.0 Manual Addendum
  822.  
  823.      -   Screen files now require that you include object class functions in
  824.          the fsyminit_struct symbol table.  You must add the following entries
  825.          to your symbol table:
  826.  
  827.              { FSYM_CLASS },
  828.              { "sedwin_Class",   (VOID_FPTR)sedwin_Class,    NULL },
  829.              { "sledwin_Class,   (VOID_FPTR)sledwin_Class,   NULL }.
  830.              { "ufunc_Class",    (VOID_FPTR)ufunc_Class,     NULL },
  831.  
  832.          Always include the entry of the delimiter "{ FSYM_CLASS }".  If you are
  833.          using seds you need the sedwin_Class entry.  If you are using sleds
  834.          then include the sledwin_Class entry.  If you are using slugs or
  835.          framers include the ufunc_Class entry.
  836.  
  837.          If you purchased Look & Feel, Look & Feel will automatically generate
  838.          the fsyminit_struct symbol table for your screens and include the
  839.          above classes as appropriate.
  840.  
  841.      -   For code portability you should use FNULL as the second member of a
  842.          fsysminit_struct, instead of NULL, if you need to specify a null
  843.          function pointer.  A null third member, the data pointer, may be
  844.          specified with NULL.  This is to insure compatibility with compilers
  845.          that differentiate between data and function pointers.
  846.  
  847.      -   There is yet another border feature that you can enable with the
  848.          sed_SetBorderFeature call:  BD_TOP.  Enabling this allows you to bring
  849.          the window to the foreground by clicking the mouse on the border.
  850.  
  851.  
  852.  
  853.  
  854. _______________________________________________________________________________
  855.  
  856. 7:  ERRATA FOR THE MANUAL
  857.  
  858. 7.1:  Errata For The 3.1 Manual
  859.  
  860.     The following are mistakes in the C-scape manual and reference.
  861.  
  862.      45           The code fragment with a reference to menu_Print lacks
  863.                   quotes.  The line in question should read:
  864.  
  865.                       menu_Printf(menu, "@f[%s], NULL, &menu_funcs, p);
  866.  
  867.  
  868.      59           In section 5.13, Auxiliary Functions, the penultimate
  869.                   sentence of the 2nd paragraph should read:
  870.  
  871.                   C-scape automatically ... and after each field's fexit
  872.                   function.
  873.  
  874.                   Not:
  875.  
  876.                   C-scape automatically .. and before each field's fenter
  877.                   function.
  878.  
  879.      63           The code example at the top of the page has a line which
  880.                   reads:
  881.  
  882.                       sed_MarkField(sed, fldno, reg, sel);
  883.  
  884.                   The line should be:
  885.  
  886.                       sed_MarkField(sed, fldno, sel, sel);
  887.  
  888.  
  889.      184-185      The example code MyTed_fkey requires
  890.  
  891.                       #include <ctype.h>
  892.  
  893.                   for the call to the call to isprint in the default case of
  894.                   the switch statement.
  895.  
  896.      158          The spc_Embed has a null case BOB_UP that falls thru to the
  897.                   UP case; BOB_DOWN falls thru to DOWN.  The cases for LEFT and
  898.                   RIGHT should be cases for SHFT_TAB and TAB, respectively.
  899.                   Also the null cases BOB_LEFT and BOB_RIGHT fall thru to
  900.                   SHFT_TAB and TAB, respectively.  See SPCEMBED.C
  901.  
  902.      160          The bob_fkey code listed before the switch is printed as:
  903.  
  904.                   {
  905.                       bob_type bob;
  906.  
  907.                       bob = sed_GetFieldBob(osed, sed_GetFieldNo(osed));
  908.  
  909.                   It should read:
  910.  
  911.                   {
  912.                       bob_type bob;
  913.                       int ret, fieldno;
  914.  
  915.                       fieldno = sed_GetFieldNo(sed);
  916.                       if ((bob = sed_GetFieldBob(osed, fieldno)) == FNULL) {
  917.  
  918.                           /* Error: no bob attached to the field */
  919.                           sed_SetBaton(osed, BOB_QUIT);
  920.                           sed_ToggleExit(osed);
  921.                           return;
  922.                       }
  923.  
  924.                       ret = bob_Go(bob);
  925.  
  926.                       /* See if special function is interested in BOB_ code */
  927.                       if (sed_DoSpecial(osed, ret))
  928.                           return;
  929.  
  930.      163          The first sentence beneath the diagram should read:
  931.  
  932.                   If you passed sed three to sed_GetAncestor it would return
  933.                   sed two.
  934.  
  935.      176,         The return value of MyTed_fexit should be:
  936.      190
  937.                       return(std_fexit(sed));
  938.  
  939.      180          The reference in the example MyTed_sexit to ted_RewindTB
  940.                   should be a reference to sed_RewindTB.
  941.  
  942.      235          bd_bar does not support a title.
  943.  
  944.      A-17         disp_GetMapEntry is described incorrectly.  It should read:
  945.  
  946.                   SYNOPSIS
  947.  
  948.                   VOID disp_GetMapEntry(index, bg, fg);
  949.  
  950.                   byte index;         /* index into the attribute map */
  951.                   opixal *bg;         /* pointer to background color */
  952.                   opixval*fg;         /* pointer to foreground color */
  953.  
  954.                   EXAMPLE
  955.  
  956.                   opixval fore, back;
  957.  
  958.                   disp_GetMapEntry(0x07, &back, &fore);
  959.  
  960.  
  961.      A-21         cmwin_Class description mentions disp_Open, it should mention
  962.                   disp_Init.
  963.  
  964.      A-24         The arguments for disp_SetMapEntry are:
  965.  
  966.                       byte index;
  967.                       opixval back;
  968.                       opixval fore;
  969.  
  970.  
  971.      A-65         kb_Idle() is a VOID (it has no return value).
  972.  
  973.      A-67         The line
  974.                       sed_SetPosition(sed, disp_GetHeight() - 1, 0);
  975.                   should be
  976.                       sed_SetPosition(timesed, disp_GetHeight() - 1, 0);
  977.  
  978.      A-89 -       You need to #include <pcmode.h> when using any of the pc_
  979.      A-92         functions.
  980.  
  981.      A-297        The synopis to sled_SetColVar is missing the begining line:
  982.  
  983.                       #include <sled.h>
  984.  
  985.      A-396        The synopsis should read valid_String(string, vstr), not
  986.                   (num, vstr).
  987.  
  988.      A-380        The function name in the synopsis should be tm_DayOfWeek, not
  989.                   tm_FirstDay.
  990.  
  991.      B-6          char_funcs does not support validation.
  992.  
  993.      B-10         date_funcs require the inclusion of the your compiler's
  994.                   TIME.H file.
  995.  
  996.      B-17         hex_funcs does not support validation.
  997.  
  998.      B-39         time_funcs require the inclusion of the your compiler's
  999.                   TIME.H file.
  1000.  
  1001. 7.2:  Errata For The 3.0 Manual
  1002.  
  1003.     The following are mistakes in the C-scape manual and reference.
  1004.  
  1005.      3            The current release does not include an ANSI terminal driver
  1006.  
  1007.      40           The code fragment with a reference to menu_Print lacks
  1008.                   quotes.  The line in question should read:
  1009.  
  1010.                       menu_Printf(menu, "@f[%s], NULL, &menu_funcs, p);
  1011.  
  1012.  
  1013.      90           spc_Embed should refer to section 10.1.1
  1014.  
  1015.      116          (5) the integer value used in the slug definition structure
  1016.                   should be a positive, NON-ZERO value.
  1017.  
  1018.      117          The type cast in the call to slug_Go should be a (VOID *),
  1019.                   not a (char *).
  1020.  
  1021.      117          The data type of "sdata" in the example user function should
  1022.                   be (VOID *), not (char *).
  1023.  
  1024.      118          (3) the integer value used in the frame definition structure
  1025.                   should be a positive, NON-ZERO value.
  1026.  
  1027.      128          spc_Embed uses TABs not arrows.
  1028.  
  1029.      142-143      In the example code pertaining to creating a sed with a ted
  1030.                   field there should be a calls to explicitly set the sed size
  1031.                   in order that the ted area be non-zero.  Use
  1032.                   sed_SetHeight(sed) and sed_SetWidth(sed) before the
  1033.                   sed_Repaint(sed) call;
  1034.  
  1035.      144,         The return value of MyTed_fexit should be:
  1036.      156
  1037.                       return(std_fexit(sed));
  1038.  
  1039.      147          The reference in the example MyTed_sexit to ted_RewindTB
  1040.                   should be a reference to sed_RewindTB.
  1041.  
  1042.      151-152      The example code MyTed_fkey requires
  1043.  
  1044.                       #include <ctype.h>
  1045.  
  1046.                   for the call to the call to isprint in the default case of
  1047.                   the switch statement.
  1048.  
  1049.      157          The example should read:
  1050.  
  1051.                   case DEL:
  1052.                       if (ted_GetMark(sed) == TED_NOMARK) {
  1053.                           /* Delete the marked region (if there is one) */
  1054.                           ted_BlockDelete(sed);
  1055.                       }
  1056.                       else {
  1057.                           /* Delete a character */
  1058.                           ted_DeleteChar(sed);
  1059.                       }
  1060.                       break;
  1061.  
  1062.  
  1063.      159          The example should read:
  1064.  
  1065.                   case ALT_S:
  1066.                       /* ... */
  1067.                           if (ted_Search(sed, search, TED_FORWARD | TED_AFTER))
  1068.                   {
  1069.                               sed_BorderPrompt(sed, FNULL);
  1070.                           }
  1071.  
  1072.      168          bd_bar does not support a title.
  1073.  
  1074.      A-15         disp_GetMapEntry is described incorrectly.  It should read:
  1075.  
  1076.                   SYNOPSIS
  1077.  
  1078.                   VOID disp_GetMapEntry(index, bg, fg);
  1079.  
  1080.                   byte index;         /* index into the attribute map */
  1081.                   opixal *bg;         /* pointer to background color */
  1082.                   opixval*fg;         /* pointer to foreground color */
  1083.  
  1084.                   EXAMPLE
  1085.  
  1086.                   opixval fore, back;
  1087.  
  1088.                   disp_GetMapEntry(0x07, &back, &fore);
  1089.  
  1090.  
  1091.      A-19         cmwin_Class description mentions disp_Open, it should mention
  1092.                   disp_Init.
  1093.  
  1094.      A-21         The arguments for disp_SetMapEntry are:
  1095.  
  1096.                   byte index;
  1097.                   opixval back;
  1098.                   opixval fore;
  1099.  
  1100.  
  1101.      A-61         kb_Idle() is a VOID (it has no return value).
  1102.  
  1103.      A-63         The line
  1104.                       sed_SetPosition(sed, disp_GetHeight() - 1, 0);
  1105.                   should be
  1106.                       sed_SetPosition(timesed, disp_GetHeight() - 1, 0);
  1107.  
  1108.      A-85 -       You need to #include <pcmode.h> when using any of the pc_
  1109.      A-88         functions.
  1110.  
  1111.      A-103        sed_Clear no longer exists.
  1112.  
  1113.      A-376        The synopsis should read valid_String(string, vstr), not
  1114.                   (num, vstr).
  1115.  
  1116.      A-360        The function name in the synopsis should be tm_DayOfWeek, not
  1117.                   tm_FirstDay.
  1118.  
  1119.      B-7          char_funcs does not support validation.
  1120.  
  1121.      B-11         date_funcs require the inclusion of the your compiler's
  1122.                   TIME.H file.
  1123.  
  1124.      B-17         hex_funcs does not support validation.
  1125.  
  1126.      B-39         time_funcs require the inclusion of the your compiler's
  1127.                   TIME.H file.
  1128.  
  1129. 7.3:  Errata For The 3.0 Manual Addendum
  1130.  
  1131.      7            The code example at the top of the page has a line which
  1132.                   reads:
  1133.  
  1134.                       sed_MarkField(sed, fldno, reg, sel);
  1135.  
  1136.                   The line should be:
  1137.  
  1138.                       sed_MarkField(sed, fldno, sel, sel);
  1139.  
  1140.  
  1141.  
  1142.  
  1143.  
  1144. _______________________________________________________________________________
  1145.  
  1146. 8:  SAMPLE PROGRAMS
  1147.  
  1148.     The following programs are included on your distribution disk to
  1149.     demonstrate the use of various parts of C-scape.  They are archived in the
  1150.     file EXAMPLE.EXE.  Compile them following the instructions listed in
  1151.     section 4, above.
  1152.  
  1153.     It is hoped that these programs will enable you to better learn C-scape;
  1154.     that you tinker with them; and, that you use them as a code source from
  1155.     which you can cut and paste to your own C-scape application.
  1156.  
  1157. 8.1: cscape
  1158.  
  1159.     CSCAPE.C is a simple data entry screen. It is the hello world of the
  1160.     C-scape world.
  1161.  
  1162. 8.2: demofm
  1163.  
  1164.     DEMOFM.C is a sample program that demonstrates one of the recommended ways
  1165.     of handling a framer menu that is driven by both the mouse and the
  1166.     keyboard.  Also demostrates the detection of mouse double-clicks and
  1167.     button1-, 2-, or 3-down events.
  1168.  
  1169. 8.3: demomous
  1170.  
  1171.     DEMOMOUS.C demonstrates mouse use with C-scape.  If you have not installed
  1172.     a mouse driver, demomous will display a message to that effect.
  1173.  
  1174. 8.4: demofram
  1175.  
  1176.     DEMOFRAM.C demonstrates the framer menuing system.  Press any key to get
  1177.     started.  Press Escape from the top menu to leave.
  1178.  
  1179. 8.5: demoslug
  1180.  
  1181.     DEMOSLUG.C demonstrates the slug menuing system.  A popup window will ask
  1182.     you if you wish to create a horizontal or vertical menuing system.  Press
  1183.     Escape from the top-most menu to leave.
  1184.  
  1185. 8.6: demosled
  1186.  
  1187.     DEMOSLED.C demonstrates how to create a screen from several smaller
  1188.     screens.  It includes a scrolling, resizing list (sled), a notepad text
  1189.     editor (ted), and mouse support.  It stores and retrieves data from the
  1190.     ASCII file DEMOSLED.DAT.  Press Escape to leave the program.
  1191.  
  1192. 8.7: demograf
  1193.  
  1194.     DEMOGRAF.C (Microsoft and Turbo Only) demonstrates how C-scape screens can
  1195.     be placed on top of graphics images.  It uses either the Microsoft or Turbo
  1196.     graphics libraries to draw the graphic images.  You must run demograf on a
  1197.     system capable of supporting graphics.  Note: on some CGA systems you may
  1198.     have to run the DOS-supplied utility GRAFTABL.COM to load the graphics
  1199.     character set.  The Turbo version of demograf looks for the Borland .BGI
  1200.     graphics driver files in the \TC directory and the directory in which you
  1201.     run it.  You can change this search path by changing the constant BGI_PATH
  1202.     in demograf.c
  1203.  
  1204. 8.8: demopcx
  1205.  
  1206.     DEMOPCX.C demostrates loading and displaying graphics images stored on disk
  1207.     using the PCX file format.
  1208.  
  1209. 8.9:  demoflod
  1210.  
  1211.     DEMOFLOD.C demonstrates loading a screen file.
  1212.  
  1213. 8.10:  demofsav
  1214.  
  1215.     DEMOFSAV.C demostrates saving a screen file.
  1216.  
  1217. 8.11: demohelp
  1218.  
  1219.     DEMOHELP.C is data entry screen that uses the C-scape help system to
  1220.     provide context sensitive help.  DEMOHELP.HLP is the accompanying help text
  1221.     file.
  1222.  
  1223. 8.12: demotty.c
  1224.  
  1225.     DEMOTTY.C is an example of using a character map window to display text in
  1226.     a tty-like fashion.
  1227.  
  1228.  
  1229.  
  1230.  
  1231. _______________________________________________________________________________
  1232.  
  1233. 9:  WHAT'S BEEN FIXED
  1234.  
  1235.      Please note that this is not a comprehensive list of the bugs we've fixed:
  1236.  
  1237.      -   To correct an erroneous definition vid_DrawBox has changed from a
  1238.          macro to a function with appropriate parameters
  1239.  
  1240.      -   def_ModeCurrent now allows the usage of 132 column and odd-sized
  1241.          displays.
  1242.  
  1243.      -   The macros for frame_Lock and frame_Unlock now work properly.
  1244.  
  1245.      -   pc_Mode7 can now be used when an EGA/VGA card is installed.
  1246.  
  1247.      -   def_ModeText no longer pre-empts mode 7 in favor of mode 3 if the
  1248.          video mode is already mode 7  - the mode will remain 7.
  1249.  
  1250.      -   Text display in graphics mode for IBM bios incompatible EGA/VGA cards
  1251.          is now supported.
  1252.  
  1253.      -   The problem of intermittent lock-ups while using the mouse - due to
  1254.          the sending of messages to invalid windows - has been corrected.
  1255.  
  1256.      -   The cursor-under pixmap is now correctly de-allocated in graphics
  1257.          mode.
  1258.  
  1259.      -   menu_DeleteRows now correctly updates the menu row count.
  1260.  
  1261.      -   pop_View now scrolls horizontally when lines wider than the width of
  1262.          the pop up are to be displayed.
  1263.  
  1264.      -   The protection of virtual fields is now respected by inter-field-grid
  1265.          movement.
  1266.  
  1267.      -   Problems moving out of scrolled virtual fields (bobbed seds) into the
  1268.          nesting sed have been corrected.
  1269.  
  1270.      -   sed_GetTB now pays attention to length of the array passed to it so
  1271.          that it doesn't trash memory.
  1272.  
  1273.      -   win_PutUnder now repaints in the case of a descending window.
  1274.  
  1275.      -   Scroll lights now correctly reflect the scrollable status of the menu
  1276.          and are properly painted upon initial display
  1277.  
  1278.      -   Sled displays now function properly in graphics mode.
  1279.  
  1280.      -   ted_fkey now correctly handles block deletion.
  1281.  
  1282.      -   sled column array (sarray) code now accomodates the case of the NULL
  1283.          array.
  1284.  
  1285.      -   kb_Record catches every keystroke.
  1286.  
  1287.      -   The window manager more fully enforces window clipping.
  1288.  
  1289.      -   You can now open a sed with a fieldless menu, then menu_Printf, and
  1290.          _Go on the sed.
  1291.  
  1292.      -   Worked around a Microsoft optimization bug that disabled Explode
  1293.          functions
  1294.  
  1295.      -   Worked around a Microsoft optimization compilation bug in
  1296.          sed_GotoLastField.
  1297.  
  1298.      -   You can now use sed_SetFieldBob to swap bobs.
  1299.  
  1300.      -   You can now delete the current field and the currfield member of the
  1301.          sed structure will be reset.
  1302.  
  1303.      -   kb_Record now works properly in teds and also records mouse events.
  1304.  
  1305.  
  1306.  
  1307.  
  1308. _______________________________________________________________________________
  1309.  
  1310. 10:  WHAT'S NEW IN THIS RELEASE
  1311.  
  1312.     These are new library features.
  1313.  
  1314.      -   Screen file (sfile) support is now present. See Chapter 4 of the
  1315.          C-scape Addendum
  1316.  
  1317.      -   Two new mouse handlers are available: sedmou_GreedyTrack and
  1318.          sedmou_GreedyClick. See Chapter 6 section 4 of the C-scape Addendum.
  1319.  
  1320.      -   All library field functions are now sensitive to the sed's mousecode.
  1321.          See chapter 6 of the C-scape addendum.
  1322.  
  1323.      -   Mouse handling capabilities are now features on all borders that can
  1324.          be enabled by means of sed_SetBorderFeature. See Chapter 6 and page
  1325.          A-16 of the C-scape Addendum.
  1326.  
  1327.      -   Auxiliary functions now offer further field function customization
  1328.          capability. See Section 2.1 ,page A-7, and page A-13 of the C-scape
  1329.          Addendum.
  1330.  
  1331.      -   Shadows are now part of all seds and can be made visible by
  1332.          sed_SetShadow. See Section 2.2, page A-21, and page A-22 of the
  1333.          C-scape Addendum.
  1334.  
  1335.      -   You can now protect a column of a sled by either using the @fp command
  1336.          in the menu_Printf when you are defining a sled row; or, by calling
  1337.          the new function sled_ProtectCol.  You can also protect a complete row
  1338.          of a sled by calling sled_ProtectRow.  Note that you cannot specify
  1339.          protection on an individual column array entry basis.  Please see the
  1340.          New Sled Functions section of this document.
  1341.  
  1342.  
  1343.  
  1344.  
  1345. _______________________________________________________________________________
  1346.  
  1347. 11:  WHAT'S IMPROVED IN THIS RELEASE
  1348.  
  1349.     These are some of the changes in C-scape 3.1 that have made it more
  1350.     efficient than 3.0:
  1351.  
  1352.      -   menu_Printf has doubled in speed.
  1353.  
  1354.      -   sled_SetColVar has been optimized to allow faster loading of the sled
  1355.          column array data.
  1356.  
  1357.      -   The framer menuing system code has been revised and now incorporates a
  1358.          new, framer-specific mouse handler.
  1359.  
  1360.      -   We've revamped our object mechanism.  We now have less indirection and
  1361.          faster access to object instance data.  And, seds are now windows (you
  1362.          no longer need to call sed_GetWin).
  1363.  
  1364.      -   The OWL makes use of far and near pointers to increase efficiency.
  1365.  
  1366.      -   General Display performance has been enhanced by more efficient
  1367.          painting of the screen.  Specifically, we no longer paint text and
  1368.          fields separately.
  1369.  
  1370.      -   Graphics display performance has been increased via direct ram screen
  1371.          writes in all modes.
  1372.  
  1373.      -   Mouse handling has been clarified in the C-scape Manual Addendum.
  1374.  
  1375.      -   The Oakland Windowing Library (OWL) now has pixmap functions and pcx
  1376.          file loading support.  See the code example demopcx.c and the section
  1377.          in this readme on cmap and pmap windows.
  1378.  
  1379.      -   Various and sundry changes and improvements have been made to the text
  1380.          handling code.
  1381.  
  1382.  
  1383.  
  1384.  
  1385. _______________________________________________________________________________
  1386.  
  1387. 12:  NEW FUNCTIONS
  1388.  
  1389.      -   nowrite_funcs is a new field function:
  1390.  
  1391.               OGLOBAL field_funcs_struct nowrite_funcs = {
  1392.                   stdNoCur_fenter,
  1393.                   std_fexit,
  1394.                   menu_fkey,
  1395.                   string_senter,
  1396.                   FNULL,
  1397.                   VAR_STRING
  1398.               };
  1399.  
  1400.          Treats the field as a menu choice.  Supports grid movement among
  1401.          fields.  Identical to menu_funcs except it uses string_senter.  The
  1402.          text of the menu choice is determined by the contents of the field's
  1403.          string variable.  Hence, it can be changed at run-time but the user
  1404.          may not edit the field.  Upon exit the value of the field is not
  1405.          written back to the variable.
  1406.  
  1407.  
  1408.      -   VOID disp_MapMono(mono)
  1409.              boolean mono;
  1410.  
  1411.          If mono is TRUE this maps colors for mono displays.  Higher values are
  1412.          generalized as lighter than lower values, with the range being from
  1413.          0-7 (8-F are moduloed, but bolding and blinking are preserved)
  1414.          therefore:
  1415.  
  1416.              fore < back (eg. 0x31) maps to 0x70
  1417.              fore > back (eg. 0x25) maps to 0x07
  1418.  
  1419.  
  1420.      -   boolean disp_ReInit(dmode)
  1421.              dmode_fptr dmode;
  1422.  
  1423.          This routine installs a new display manager without closing down the
  1424.          window manager.  It restore the mode that existed prior to disp_Init,
  1425.          changes the display mode, and repaint the display.  You might use it
  1426.          to change from text mode to EGA 43 line mode and back:
  1427.  
  1428.              disp_Init(def_ModeText, FNULL);
  1429.              /* ... */
  1430.              disp_ReInit(pc_ModeEGA43);
  1431.              /* ... */
  1432.              disp_ReInit(def_ModeText);
  1433.  
  1434.  
  1435.      -   bob_type ufunc_Open(ufunc, idata)
  1436.              ufunc_fptr ufunc;
  1437.              int idata;
  1438.  
  1439.          Creates a bob from a user function.  Returns the bob if successful;
  1440.          NULL if not.  The idata argument is a value that is passed to the user
  1441.          function upon invocation.
  1442.  
  1443.      -   VOID *sed_GetCurrFieldData(sed, datano);
  1444.              sed_type sed;
  1445.              int datano;
  1446.  
  1447.          Similar to sed_GetFieldData except that it refers to the current
  1448.          field.
  1449.  
  1450.  
  1451.  
  1452.  
  1453. _______________________________________________________________________________
  1454.  
  1455. 13:  NEW SLED FUNCTIONS
  1456.  
  1457.     Please note that the header file SLEDWIN.H is now named SLED.H.  If in your
  1458.     older code you had included BOBSLED.H for sled function use then you need
  1459.     make no changes - BOBSLED.H includes SLED.H.  If you had explicitly used
  1460.     SLEDWIN.H then change the references to SLED.H.
  1461.  
  1462.     New routines have been added to the library to allow the protection and
  1463.     marking of row and columns in sleds (scrolling list editors).  Protection
  1464.     and marking can be done independently of each other.  Every attempt has
  1465.     been made to keep the sled functions as close as possible to their field
  1466.     counterparts.
  1467.  
  1468.     Any row or column can be protected using the appropriate function calls.
  1469.     Any changes to a row or column's protection status take effect the next
  1470.     time sled_Remap or sled_Repaint is called.  Be careful that you do not
  1471.     attempt to protect the current row or column without moving out of it
  1472.     IMMEDIATELY afterward.
  1473.  
  1474.     Highlighting can be added to a sled by using the sled_Mark and sled_Attr
  1475.     routines.  As with protection, changes take effect the next time sled_Remap
  1476.     is called.  All rows and columns will be marked with the same regular and
  1477.     selected attributes.  The attribute can be changed or inspected with
  1478.     sled_SetMarkAttr() and sled_GetMarkAttr().  The attributes are
  1479.     uninitialized, so you should call sled_SetMarkAttr() before you mark
  1480.     anything.
  1481.  
  1482.     Both protecting and marking can be done to any sled row or column, whether
  1483.     it is currently displayed or not.
  1484.  
  1485.     Return the current marking colors in regular and selected:
  1486.  
  1487.          OEXTERN VOID sled_GetMarkAttr(sed, regular, selected);
  1488.              sed_type     sed;
  1489.              byte    *regular;
  1490.              byte    *selected;
  1491.  
  1492.     Set the sled's marking colors to regular and selected":
  1493.  
  1494.          OEXTERN VOID sled_SetMarkAttr(sed, regular, selected);
  1495.              sed_type sed;
  1496.              byte regular;
  1497.              byte selected;
  1498.  
  1499.     Use these routines to check the mark status of a row or column:
  1500.  
  1501.          boolean sled_IsMarkedRow(sed, row);
  1502.              sed_type sed;
  1503.              int row;
  1504.  
  1505.          boolean sled_IsMarkedCol(sed, col);
  1506.              sed_type sed;
  1507.              int col;
  1508.  
  1509.     These routines are for marking or unmarking and row or column in a sled:
  1510.  
  1511.          #define sled_MarkRow(sed, row);
  1512.              sed_type sed;
  1513.              int row;
  1514.  
  1515.          #define sled_UnMarkRow(sed, row);
  1516.              sed_type sed;
  1517.              int row;
  1518.  
  1519.          #define sled_MarkCol(sed, col);
  1520.              sed_type sed;
  1521.              int col;
  1522.  
  1523.          #define sled_UnMarkCol(sed, col);
  1524.              sed_type sed;
  1525.              int col;
  1526.  
  1527.     Use these routines to check the protect status of a row or column:
  1528.  
  1529.          boolean sled_IsProtectedRow(sed, row);
  1530.              sed_type sed;
  1531.              int row;
  1532.  
  1533.          boolean sled_IsProtectedCol(sed, col);
  1534.              sed_type sed;
  1535.              int col;
  1536.  
  1537.     Protect a row or col with these routines.  Use "b" to pass TRUE or FALSE,
  1538.     indicating whether you want protection ON or OFF:
  1539.  
  1540.          VOID sled_ProtectRow(sed, row, b);
  1541.              sed_type sed;
  1542.              int row;
  1543.              boolean b;
  1544.  
  1545.          VOID sled_ProtectCol(sed, col, b);
  1546.              sed_type sed;
  1547.              int col;
  1548.              boolean b;
  1549.  
  1550.  
  1551.  
  1552.  
  1553. _______________________________________________________________________________
  1554.  
  1555. 14:  CMAP AND PMAP WINDOWS
  1556.  
  1557.     Seds are windows of the sedwin_Class.  This is the most common C-scape
  1558.     window.  There are there other window types available in the Oakland
  1559.     Windowing Library (OWL), however.
  1560.  
  1561.     We will take a brief look at two of these other windows - cmap and pmap
  1562.     windows.  The forthcoming Oakland Advanced Programming Guide is the manual
  1563.     for the OWL and will provide a more in-depth look at window classes and
  1564.     objects.  Here we present the rudiments.
  1565.  
  1566.     Character map (cmap) windows are of the cmwin_Class.  Pixel map (pmap)
  1567.     windows are of the pmwin_Class.   A character map is a two-dimensional
  1568.     array of characters and attributes; a pixel map is a bit map of video ram.
  1569.  
  1570.     You can create a window with win_Open.  This routine creates an object of
  1571.     class winclass.  The starting size and position (in display coordinates) is
  1572.     given by the ocbox cboxp.  The window is placed in the unemployed window
  1573.     list.  win_Open returns a pointer to the newly created window or NULL if
  1574.     unsuccessful.
  1575.  
  1576.          win_type win_Open(winclass, cboxp)
  1577.              class_fptr      winclass;   /* window class */
  1578.              ocbox           *cboxp;     /* character box pointer */
  1579.  
  1580.  
  1581.     You employ the window  - painting it to the display - with win_Employ.
  1582.  
  1583.          boolean win_Employ(win)
  1584.              win_type        win;        /* the window to hire */
  1585.  
  1586.  
  1587.     The window is fired - removing it from the display without destroying it -
  1588.     by calling with win_UnEmploy.
  1589.  
  1590.          boolean win_UnEmploy(win)
  1591.              win_type        win;        /* the window to fire */
  1592.  
  1593.  
  1594.     You can destroy the window with win_Close.  This removes the window from
  1595.     the display and deallocates its storage.
  1596.  
  1597.          VOID win_Close(win)
  1598.              win_type        win;        /* the window to destroy */
  1599.  
  1600.  
  1601.     Some common additional functions enable you to attached a border, set the
  1602.     window position, and create a bob from the window so that you may nest it
  1603.     within a sed.
  1604.  
  1605.          boolean win_SetBorder(win, bd)
  1606.              win_type        win;            /* the window to which to attach
  1607.          */
  1608.              class_fptr      bd;             /* the border */
  1609.  
  1610.  
  1611.          viod win_SetPosition(win, row, col)
  1612.              win_type        win;
  1613.              int             row;            /* display relative */
  1614.              int             col;
  1615.  
  1616.  
  1617.          bob_type win_CreateBob(win, depend)
  1618.              win_type        win;
  1619.              int             depend;
  1620.  
  1621.              /*
  1622.                  depend is either BOB_DEPEND or BOB_INDEPENDENT
  1623.                  a dependent bob will be painted and moved with
  1624.                  its parent, while an independent bob must be painted
  1625.                  separately
  1626.              */
  1627.  
  1628.     You can display text in the cmap window by string the text in the cmap:
  1629.  
  1630.          char *cmwin_DrawString(win, row, col, string, attr, slen)
  1631.              win_type        cmap;
  1632.              int             row;
  1633.              int             col;
  1634.              char            *string;            /* terminated string */
  1635.              byte            attr;
  1636.              int             slen;
  1637.          /*
  1638.              Places string within window's cmap, clipping against cmap edges.
  1639.              Puts blanks from end of string to slen if string was too short.
  1640.              String is not read after a newline or a '\0'.
  1641.              Coords are relative to cmap.
  1642.              For blanks past the end of the string, attribute 'attr' is used.
  1643.              Returns pointer to char after last one put into cmap.
  1644.          */
  1645.  
  1646.  
  1647.     You display images in a pmap window by opening, loading, and attaching the
  1648.     pmap.
  1649.  
  1650.     The only stock method provided by the OWL for loading a pmap from a PCX
  1651.     graphics format file.  If you have images in other file formats there are
  1652.     many available utilities that will perform conversion to PCX format.
  1653.  
  1654.     The PCX file interface must be intialized by calling pmap_IoInit.
  1655.  
  1656.          VOID pmap_IoInit()
  1657.  
  1658.     You then create a color map capable of holding the range of colors that
  1659.     will be used to create the image by calling ocolmap_Open.  This routine
  1660.     takes an index, firstpix, a the number of entries the color map will have,
  1661.     nentries.  You get back a color map with the entries set to black; or, NULL
  1662.     if the range of the map was outside that of the default sytem map.
  1663.  
  1664.          ocolmap_type ocolmap_Open(firstpix, nentries)
  1665.              opixval         firstpix;s
  1666.              unsigned        nentries;
  1667.  
  1668.  
  1669.     You load a map from a PCX file that you've opened in "rb" (read binary)
  1670.     mode by calling pmap_Load.  Note that when you open a pmap window with
  1671.     win_Open the pmap is not allocated.  pmap_Load reads the .pcx file,
  1672.     initializing your colormap, allocates a pmap and loads it with the PCX file
  1673.     image. A pointer to the pmap is returned to you.
  1674.  
  1675.          pmap_type pmap_Load(fp, crange)
  1676.              FILE            *fp;
  1677.              ocolmap_type    crange;
  1678.  
  1679.  
  1680.     (If you wished to open a pmap - intending to load it yourself - you would
  1681.     call pmap_Open.  This routine takes a pixel size specification and creates
  1682.     a pmap window.  You are returned the window; or, NULL if it could not be
  1683.     opened.)
  1684.  
  1685.          pmap_type pmap_Open(pixwidth, pixheight)
  1686.              odim        pixwidth;       /* this type is currently defined */
  1687.              odim        pixheight;      /* to be an unsigned int */
  1688.  
  1689.  
  1690.     pmap_Load does not, itself, set the system palette up with your color map.
  1691.     To do this you make a separate call to disp_SetColMap once pmap_Load has
  1692.     initialized the color map from the PCX file.
  1693.  
  1694.          VOID disp_SetColMap(map)
  1695.              ocolmap_type map;
  1696.  
  1697.  
  1698.     After opening a pmap, either by pmap_Open or pmap_Load, you attach the pmap
  1699.     to the pmap window with pmwin_SetPmap.
  1700.  
  1701.          VOID pmwin_SetPmap(win, pmap)
  1702.              win_type        win;
  1703.              pmap_type       pmap;
  1704.  
  1705.  
  1706.     You initially paint the window to the display with win_Employ, as mentioned
  1707.     above.
  1708.  
  1709.     You can refresh the display of a cmap or a pmap window with win_Paint.
  1710.     win_Paint only paints the window.  If you wish to paint the border, any
  1711.     window shadow, and the window then call bord_Paint.  In general, win_ calls
  1712.     affect only the window; bord_ calls affect the window and border.  If you
  1713.     have nested it by the used of win_CreateBob, call sed_Repaint.  Alternating
  1714.     use of either of pmwin_SetPmap and win_Paint can produce an animated image.
  1715.  
  1716.          VOID win_Paint(win)
  1717.              win_type        win;    /* paint only the window */
  1718.  
  1719.  
  1720.          VOID bord_Paint(win)
  1721.              win_type        win;    /* paint window,border,and shadow */
  1722.  
  1723.  
  1724.     When you are done with the pmap you destroy it with pmap_Close.  Make sure
  1725.     to nullify the pmap window's pointer to the map by calling
  1726.     pmwin_SetPmap(win, NULL).  win_Close is used to destroy the pmap window
  1727.     itself but note, win_Close will not deallocate any associated pmap - you
  1728.     must call pmap_Close explicity.
  1729.  
  1730.          boolean pmap_Close(pmap)
  1731.              pmap_type;
  1732.  
  1733.  
  1734.     Please see the two sample programs in the EXAMPLE.EXE archive, DEMOTTY.C
  1735.     and DEMOPCX.C, for the details of the call sequences used to display cmap
  1736.     and pmap windows.
  1737.  
  1738.     You may consult the source for cmwin_Class and pmwin_Class in CMWIN.C and
  1739.     PMWIN.C, respectively.  The headers CMWINOBJ.H and PMWINOBJ.H will give you
  1740.     some listing of function macros pertinent to these window classes.
  1741.  
  1742.  
  1743.  
  1744.  
  1745. _______________________________________________________________________________
  1746.  
  1747. 15:  OAKLAND DEBUGGING AID
  1748.  
  1749.     This is not an example program but rather a debugging aid.
  1750.  
  1751.     In order to aid in tracking down memory problems under DOS we have include
  1752.     a file OAKMEMOK.C in the example archive. The functions contained in
  1753.     OAKMEMOK.C replace the current memory handling routines used by C-scape.
  1754.     The C-scape memory allocation routines are simple shells around calls to
  1755.     the C run time library allocators.  OAKMEMOK.C has some additional
  1756.     functionality:
  1757.  
  1758.          It places a guard byte before and after each block at the time of
  1759.          allocation;
  1760.  
  1761.          it keeps a linked list of each block that is allocated complete with a
  1762.          tag that identifies what C-scape object has been allocated or freed;
  1763.          and,
  1764.  
  1765.          it checks the integrity of the guard bytes for each block of memory in
  1766.          the linked list whenever an allocation is made.
  1767.  
  1768.     Of particular note in OAKMEMOK.C is a function called alloc_test.  The
  1769.     allocation routines use this function to perform the check of the linked
  1770.     list of memory blocks.  This function takes two arguments: a prompt and a
  1771.     mode.  alloc_test returns 0 if the heap is OK.  If one of the blocks has
  1772.     had its guard bytes overwritten then it returns the the tag value of the
  1773.     bad block.
  1774.  
  1775.         int alloc_test(char *msg, int mode)
  1776.  
  1777.     The value of mode determines the verbosity of the report:
  1778.  
  1779.     0   silent
  1780.     1   print summaries
  1781.     2   print dump list - Print the entire list of blocks and tags
  1782.  
  1783.     When alloc_test prints it does so by means of a printf.
  1784.  
  1785.     When the allocation routines call this they pass a NULL msg and a mode 0.
  1786.     If a bad block is detected the allocation routine will print an error
  1787.     message noting the bad block's tag.  Again, printf is used for the output.
  1788.  
  1789.     To use this aid, compile and link OAKMEMOK.C with your application.  Note
  1790.     that you must include the header DEBUG.H.  (If you are compiling under
  1791.     Microsoft, remember to pass the /NOE switch to the linker so that
  1792.     references to the memory allocation routines are resolved by the functions
  1793.     in the oakmemok.obj module, not the library.)  Every allocation will
  1794.     automatically perform a check on the list of memory blocks and print an
  1795.     error message if the check fails.
  1796.  
  1797.     To pinpoint when and where in your application memory is getting trashed
  1798.     (usually by a bad pointer) you must often call alloc_test explicitly.
  1799.     Pepper your code with calls to this function to localize the error.
  1800.     Sometimes you may also find it necessary to compile those C-scape source
  1801.     modules pertinent to where the error is occuring with the debug switch set
  1802.     and then link these with your application so you can trace into the library
  1803.     and locate an error.  This is particularly true in cases where you have
  1804.     modified library code or are otherwise unable to localize the error.  When
  1805.     you do this, add alloc_test calls to library source as needed.
  1806.  
  1807.     Since alloc_test and other routines in OAKMEMOK.C us printf to perform
  1808.     output you can redirect this to a file on the DOS command line:
  1809.  
  1810.         myprogrm >myprogrm.err
  1811.  
  1812.  
  1813.     These functions aid in tracking down memory faults but they are not full
  1814.     proof. They can not detect when a memory block has been overwritten without
  1815.     affecting the guard bytes.  Despite this limitation they are very good for
  1816.     tracking down most memory errors.
  1817.  
  1818.  
  1819.  
  1820.  
  1821. _______________________________________________________________________________
  1822.  
  1823. 16:  A FEW OAKLAND CODE CONVENTIONS
  1824.  
  1825.     The following are a some code convention we use to insure code portability.
  1826.     While not required for DOS and OS/2 it is suggested that you incorporate
  1827.     such conventions in your C-scape application code for ease of porting to
  1828.     other operating systems.
  1829.  
  1830. 16.1:  OGLOBAL
  1831.  
  1832.     In the .c files of C-scape and the OWL, you'll see the use of OGLOBAL -
  1833.     most notably before the definition of a particular field function's
  1834.     field_funcs_struct.
  1835.  
  1836.     Under most operating systems, DOS and OS/2 included, this symbol is
  1837.     conditionally defined by our headers to macro out to nothing.
  1838.  
  1839.     But because of the way compilers for some systems, VMS specifically, treat
  1840.     structure initialization, it is necessary to provide a mechanism for
  1841.     expanding OGLOBAL to something else.  Under VMS, our headers expand it to
  1842.     "globaldef" - a keyword peculiar to the compilers for that system which
  1843.     allows the proper compilation of such code.
  1844.  
  1845. 16.2:  OEXTERN
  1846.  
  1847.     In the .h files of C-scape and the OWL, you'll see the use of OEXTERN in
  1848.     declarations of variables that are defined elsewhere.
  1849.  
  1850.     Under most operating systems, DOS and OS/2 included, this symbol is
  1851.     conditionally defined by our headers to macro out to the standard 'C'
  1852.     keyword "extern".
  1853.  
  1854.     But because of the way compilers for some systems, VMS specifically, treat
  1855.     allocation, it is necessary to provide a mechanism for expanding OEXTERN to
  1856.     something else.  Under VMS, our headers expand it to "globalref" - a
  1857.     keyword peculiar to the compiler for that system without which such code
  1858.     would not properly compile.
  1859.  
  1860. 16.3:  FNULL
  1861.  
  1862.     C-scape 3.1 library code now makes a distinction between a data and a
  1863.     function pointer.  In accord with this, if you have occasion to specify a
  1864.     null function pointer you should use FNULL instead of NULL.  Microsoft C,
  1865.     Turbo C and most compilers for DOS and OS/2 won't complain if you don't do
  1866.     this, but compilers for other systems may.  You should do this for the sake
  1867.     of code portability.
  1868.  
  1869.     For example, where you used to write:
  1870.  
  1871.         disp_Init(def_ModeText, FNULL);
  1872.  
  1873.     you should now write:
  1874.  
  1875.         disp_Init(def_ModeText, FNULL);
  1876.  
  1877.  
  1878.     What else is affected by this?  In general, null pointers in references to
  1879.     borders, mouse handlers, user supplied functions, class functions, explode
  1880.     functions, auxiliary functions, special functions, and the component
  1881.     functions of field_funcs.
  1882.  
  1883.     Here is a summary of the functions or structures refered to in the C-scape
  1884.     3.0 and 3.1 Manual Function References and in the C-scape 3.0 Manual
  1885.     Addendum that are affected by this:
  1886.  
  1887.          those that deal with borders -
  1888.              frame_Open,
  1889.              slug_Open,
  1890.              pop_View, _Edit, _Prompt, _Menu, _Message, _Text,
  1891.              the hx_struct or hv_struct you pass to help_Init;
  1892.  
  1893.          with mouse handlers -
  1894.              sed_SetMouse;
  1895.  
  1896.          user supplied functions -
  1897.              kb_Idle,
  1898.              the slug_def structure that you pass to slug_Open,
  1899.              the frame_def structure that you pass to frame_Open;
  1900.  
  1901.          class functions -
  1902.              disp_Init;
  1903.  
  1904.          explode functions -
  1905.              sed_SetExplode;
  1906.  
  1907.          auxiliary functions -
  1908.              sed_SetAux;
  1909.  
  1910.          special functions -
  1911.              sed_SetSpecial,
  1912.              sled_Open;
  1913.  
  1914.          and field_funcs component functions -
  1915.              _senter,
  1916.              _sexit,
  1917.              _fenter,
  1918.              _fkey,
  1919.              _fexit.
  1920.  
  1921.          In addition, the list of fsyminit_structs necessary for use with
  1922.          screen files is affected.  The fsyminit_struct has three members.  The
  1923.          first is a string, the second a function pointer and the third a data
  1924.          pointer.  The type casts used for the last two members, as discussed
  1925.          in the manual, are (VOID_FPTR) and (VOID *).  Likewise, FNULL and NULL
  1926.          should be used when you wish to initialize these last two members of
  1927.          an fsyminit_struct list entry to a null value.
  1928.  
  1929.  
  1930.  
  1931.  
  1932. _______________________________________________________________________________
  1933.  
  1934. 17:  RECOMPILING THE SOURCE CODE
  1935.  
  1936. 17.1:  General
  1937.  
  1938.     Should you wish to use C-scape with another compiler you can purchase the
  1939.     object files for that compiler from us for $100. You can also recompile the
  1940.     source yourself.  We will not be obligated to support recompiled source
  1941.     code, however.
  1942.  
  1943.     Note that on the distribution disks we have included a Make file suitable
  1944.     for the Turbo-C and Opus Make utility to facilitate recompilation.  If you
  1945.     use a makefile the object modules produced will automatically be organized
  1946.     into a library.  If you do not use the makefile and wish to form a library
  1947.     then you will have to use a librarian utility such as Microsoft's LIB
  1948.     utility or Borland's TLIB. When recompiling your source, use the
  1949.     appropriate compiler and assembler flags listed below,
  1950.  
  1951.     In general, recompiling the source is a matter of getting to know the make
  1952.     utility provided with your compiler. We provide makefiles for the Turbo-C
  1953.     Make utility and the Opus Make utility.
  1954.  
  1955.     C-scape makes extensive use of function prototyping.  If you are
  1956.     recompiling the source and the compiler you are using does not support
  1957.     prototyping you must define the symbol NO_PROTO in the compile command to
  1958.     disable the prototyping used in the C-scape source.  Consult OAKLAND.H to
  1959.     see how this is implemented.
  1960.  
  1961. 17.2:  Microsoft C Make
  1962.  
  1963.     Programmers using Microsoft's make utility should be aware that the default
  1964.     make provided puts severe constraints upon the user. A 512 character limit
  1965.     on macro expansion space as well as nonstandard filename macros tend to
  1966.     render this make utility very difficult to use for large projects. For this
  1967.     reason we do not supply a microsoft make specific makefile. For those who
  1968.     do wish to produce such a makefile, the Turbo-C makefile will act as a good
  1969.     starting point.
  1970.  
  1971.     The major changes that will need to be made consist of breaking up the OBJ
  1972.     macros into several smaller groupings and generating a response file for
  1973.     the LIB utility. See the Microsoft C documentation for details.
  1974.  
  1975. 17.2.1:  OWL
  1976.  
  1977.     The actual command line used in producing the OWL object modules is:
  1978.  
  1979.     cl /c /DM5 /AL /FPc /W3 /I. /Zl /Olt /Tc FILENAME
  1980.  
  1981.     We must caution you that the optimization flags /Ox /Oa can cause very
  1982.     unpredictable effects in C-scape code. The Oakland Group will not support
  1983.     C-scape library source that has been recompiled with the /Ox or /Oa
  1984.     switches
  1985.  
  1986.     Note that the above assumes that you are using only DOS. If you were
  1987.     compiling the library for OS/2 use in addition to DOS you would add the
  1988.     -DOAK_OS2  and -OAK_FAMILYAPI
  1989.  
  1990.     The MASM command line for the assembler modules is :
  1991.  
  1992.     L Model
  1993.  
  1994.     masm /ML /DM5=99 /DLMOD=99 oakint86.asm, \M1L\;
  1995.  
  1996.     M Model
  1997.  
  1998.     masm /ML /DM5=99 /DMMOD=99 oakint86.asm, \M1M\;
  1999.  
  2000. 17.2.2:  CSCAPE
  2001.  
  2002.     The command line used in producing the CSCAPE object modules is:
  2003.  
  2004.     cl /c /DM5 /AL /FPc /W3 /I. /Zl /Olt /Tc FILENAME
  2005.  
  2006.     We must caution you that the optimization flags /Ox /Oa can cause very
  2007.     unpredictable effects in C-scape code. The Oakland Group will not support
  2008.     C-scape library source that has been recompiled with the /Ox or /Oa
  2009.     switches
  2010.  
  2011.     Note that the above assumes that you are using only DOS. If you were
  2012.     compiling the library for OS/2 use in addition to DOS you would add the
  2013.     -DOAK_OS2  and -OAK_FAMILYAPI.
  2014.  
  2015. 17.3:  Turbo-C 2.0 Make
  2016.  
  2017. 17.3.1:  OWL
  2018.  
  2019.     A Turbo-C specific makefile (T2OWL.MAK) and a response file (TC2OWL.RSP)
  2020.     are provided in source archive OWLSRC.EXE and should be usable with only
  2021.     minor modifications. The makefile assumes that you are using TASM rather
  2022.     than MASM.
  2023.  
  2024.     The OWL library is really composed of several sub-libraries, each with its
  2025.     own compile line. The main difference between the compile lines is a flag
  2026.     that sets the name of the code segment for the object module. Each
  2027.     sub-library has the same code segment name. This allows us to make near
  2028.     calls within certain portions of the library.
  2029.  
  2030.     The command line for the OWL library is :
  2031.  
  2032.     tcc -c -ml -w -G -O -Z -zCOWL_TEXT -f FILENAME
  2033.  
  2034.     The above command line assumes that your TURBOC.CFG file is fairly simple
  2035.     and will not conflict with any of the options described here.
  2036.  
  2037.     The assembler files in the OWL library should assembled using the following
  2038.     flags:
  2039.  
  2040.     l Model
  2041.  
  2042.     tasm /ml /dTC=99 /dlMOD=99 /dOWLSEG=99 FILENAME.asm,,;
  2043.  
  2044.     m Model
  2045.  
  2046.     tasm /ml /dTC=99 /dmMOD=99 /dOWLSEG=99 FILENAME.asm,,;
  2047.  
  2048. 17.3.2:  CSCAPE
  2049.  
  2050.     A Turbo-C specific makefile (T2CSCAP.MAK) and two response files
  2051.     (T2CSCAP1.RSP ,T2CSCAP2.RSP) are provided in source archive CSCAPSRC.EXE
  2052.     and should be usable with only minor modifications.
  2053.  
  2054.     The command line for the CSCAPE library is :
  2055.  
  2056.     tcc -c -ml -w -G -O -Z -f FILENAME
  2057.  
  2058.     The above command line assumes that your TURBOC.CFG file is fairly simple
  2059.     and will not conflict with any of the options described here.
  2060.  
  2061. 17.4:  Opus Make 5.0
  2062.  
  2063.     The Opus Make utility is used in-house at the Oakland group. It is
  2064.     available from Opus Software (415) 664-7901 . We have found it to be very
  2065.     effective and flexible make utility.
  2066.  
  2067.     We provide a initialization file (MAKE.INI) and a makefile (MAKEFILE) in
  2068.     the source archive OWLSRC.EXE . We provide a makefile (MAKEFILE) in the
  2069.     source archive CSCAPSRC.EXE .
  2070.  
  2071.  
  2072.  
  2073.  
  2074. _______________________________________________________________________________
  2075.  
  2076. 18:  OS/2
  2077.  
  2078.     The Microsoft version of the C-scape 3.0 libraries can be used to create
  2079.     OS/2 applications.
  2080.  
  2081.     Only def_ModeText is currently supported under OS/2.  Graphics mode is not
  2082.     currently supported under OS/2.  We will, at some future date, support
  2083.     graphics under the OS/2 Presentation Manager.
  2084.  
  2085.     To create an OS/2 application you must define the symbol OAK_OS2 when
  2086.     compiling your source.
  2087.  
  2088.     The basic compile line is:
  2089.  
  2090.         cl /c /DM5 /DOAK_OS2 /I\cscape\include myprog.c
  2091.  
  2092.  
  2093.     OAK_OS2 may also be placed in your source file.  If you place it in your
  2094.     source file you don't need to define it on the command line.  If you do
  2095.     this, you should place the definition in the your .c file that contains the
  2096.     disp_Init call and you must place it before the include statements.
  2097.  
  2098.         #define OAK_OS2             /* for OS/2 */
  2099.  
  2100.         #include <stdio.h>
  2101.         #include <cscape.h>
  2102.  
  2103.         /* ... */
  2104.  
  2105.         {
  2106.             disp_Init(def_ModeText, FNULL);
  2107.  
  2108.             /* ... */
  2109.  
  2110.  
  2111.     Please note that when OS/2 version 1.0 changed to OS/2 Extended Edition 1.1
  2112.     the library DOSCALLS.LIB was renamed to OS2.LIB.  Along with that change,
  2113.     one of the functions changed its name slightly.  What was called DosGetPid
  2114.     is now DosGetPID.  The Microsoft 5.1 LIBCEP libraries however, still refer
  2115.     to DOSCALLS.LIB.
  2116.  
  2117.     The current call name, DosGetPID, is what appears in OWL source.  If you
  2118.     are compiling for OS/2 E.E. 1.1, all is well.
  2119.  
  2120.     If, however, you are compiling for OS/2 1.0 then you must make an
  2121.     additional step.  Redefine the current call name back to the older one so
  2122.     that the linker can find DosGetPid.  You redefine this in the OWL module
  2123.     that has the call reference - OS2HARD.C:
  2124.  
  2125.         #define DosGetPID DosGetPid     /* define for compat. with 1.0 */
  2126.  
  2127.     then recompile OS2HARD.C.  Note that this must be compiled in a code
  2128.     segment that bears the name "OWL_TEXT" (use the /NT flag to name the
  2129.     segment).  Then, replace OS2HARD.C in the OWL library.
  2130.  
  2131.     After compilation you must link with the OWL, C-scape and C run time
  2132.     libraries.
  2133.  
  2134.     For Microsoft 5.1 with OS/2 prior to the Extended Edition 1.1:
  2135.  
  2136.         link /SE:500 myprog.obj,,,LLIBCEP.LIB \cscape\lib\m1lowl.lib
  2137.              \cscape\lib\m1lcscap.lib;
  2138.  
  2139.     For Microsoft 5.1 with OS/2 Extended Edition 1.1:
  2140.  
  2141.         link /NOE /SE:500 myprog.obj,,,OS2.LIB LLIBCEP.LIB
  2142.              \cscape\lib\m1lowl.lib \cscape\lib\m1lcscap.lib;
  2143.  
  2144.     If you wish to create a family mode application add the following to the
  2145.     above steps.
  2146.  
  2147.     Define both OAK_FAMILYAPI and OAK_OS2 in the compile command line for the
  2148.     recompilation of the three OS2 files in the OWL: OS2HARD.C, OS2DISP.C and
  2149.     OS2OPEN.C.  After this you may link these with your application:
  2150.  
  2151.     Again, for Microsoft 5.1 with OS/2 prior to the Extended Edition 1.1:
  2152.  
  2153.         link /SE:500 myprog os2hard os2disp os2open, myprog, , LLIBCEP.LIB
  2154.              \cscape\lib\m1lowl.lib  \cscape\lib\m1lcscap.lib;
  2155.  
  2156.     For Microsoft 5.1 with OS/2 Extended Edition 1.1:
  2157.  
  2158.         link /NOE /SE:500 myprog os2hard os2disp os2open, myprog, , OS2.LIB
  2159.              LLIBCEP.LIB \cscape\lib\m1lowl.lib \cscape\lib\m1lcscap.lib;
  2160.  
  2161.     Then bind your family api application.
  2162.  
  2163.     For OS/2 prior to Extended Edition version 1.1:
  2164.  
  2165.         bind myprog.exe doscalls.lib api.lib -n @bind.exc
  2166.  
  2167.     For OS/2 Extended Edition version 1.1:
  2168.  
  2169.         bind myprog.exe os2.lb api.lib -n @bind.exc
  2170.  
  2171.     For the bind, bind.exc is a text file containing the following lines:
  2172.  
  2173.          DOSCREATETHREAD
  2174.          DOSENTERCRITSEC
  2175.          DOSEXITCRITSEC
  2176.          DOSGETPID
  2177.          DOSMUXSEMWAIT
  2178.          DOSSEMCLEAR
  2179.          DOSSEMREQUEST
  2180.          DOSSEMSET
  2181.          DOSSEMWAIT
  2182.          MOUDRAWPTR
  2183.          MOUGETNUMQUEEL
  2184.          MOUOPEN
  2185.          MOUREADEVENTQUE
  2186.          MOUREMOVEPTR
  2187.          MOUSETDEVSTATUS
  2188.  
  2189.     This file is necessary because our code contains references to OS2 calls
  2190.     above which have no family api counterparts.  The bind utility is warning
  2191.     us of this - it would be a problem to run under DOS.  But our own provides
  2192.     the functionality to perform the associated tasks under DOS so we may
  2193.     ignore these.
  2194.  
  2195.  
  2196.  
  2197.  
  2198.  
  2199. _______________________________________________________________________________
  2200.  
  2201. 19:  OAKLAND TECHNICAL SUPPORT
  2202.  
  2203.     The Oakland Bulletin Board telephone number is (617) 491-1644.  It is
  2204.     accessible at both 1200 and 2400 baud.  The line protocol is 8 data bits,
  2205.     No parity, and 1 Stop bit.
  2206.  
  2207.     We encourage all to use the bulletin board as a forum by which to share
  2208.     C-scape ideas, comments and code (field functions, drivers, borders, etc.)
  2209.     with others.
  2210.  
  2211.  
  2212.  
  2213.  
  2214. _______________________________________________________________________________
  2215.  
  2216. 20:  WHAT IS COMING FROM OAKLAND
  2217.  
  2218.     As adjuncts to the C-scape Manual two additional Oakland publications are
  2219.     mentioned in the its Introduction.  Note that The Oakland Advanced
  2220.     Programming Guide and The C-scape Cookbook are both, as yet, under
  2221.     development.  All registered users of C-scape will be automatically
  2222.     notified of their availability when completed.
  2223.  
  2224.     Of all references to C-Spot and C-Cell software, note that these products
  2225.     are under developement and not yet available.  Registered user's of C-scape
  2226.     will be automatically notified of their availability when completed.
  2227.