home *** CD-ROM | disk | FTP | other *** search
/ Liren Large Software Subsidy 10 / 10.iso / l / l360 / 1.ddi / README.DOC < prev    next >
Encoding:
Text File  |  1991-08-05  |  19.1 KB  |  485 lines

  1.  
  2.                  README.DOC File
  3.  
  4.          Release Notes for the Microsoft(R) COBOL
  5.              Professional Development System
  6.                    Version 4.5
  7.  
  8.          (C) Copyright Microsoft Corporation, 1991
  9.  
  10.   This document contains essential information for version 4.5 of the
  11.   Microsoft COBOL Professional Development System for MS-DOS(R) and the
  12.   Microsoft Operating System/2 (MS(R) OS/2(R)). The information in this
  13.   document is more up to date than that in the manuals.
  14.  
  15.   Microsoft improves its languages documentation at the time of reprinting,
  16.   so some of the information in this file may already be included in your
  17.   manuals.
  18.  
  19.  
  20.   NEW FEATURES
  21.  
  22.    o  Support for Windows 3.0
  23.  
  24.       The following types of programs are supported under Windows 3.0 :
  25.  
  26.       - Existing DOS applications can be linked with a new runtime library
  27.     (COBAPIDW) to produce an application that runs under Windows.
  28.  
  29.       - Programs that call the Windows API can now be written in 
  30.     COBOL.  Note that if you do not have the Windows Software 
  31.     Development Kit (SDK) and plan to create true COBOL Windows
  32.     applications by calling the Windows API directly, you may be
  33.     interested in using the Dialog Editor from the SDK.  The Dialog
  34.     Editor is available through PSS by calling 637-7096.
  35.  
  36.       - Dynamic-link libraries that can be called from programs written
  37.     in other programming languages can be written in COBOL.
  38.  
  39.    o  Intrinsic Functions
  40.  
  41.       The 1989 Addendum to the ANSI 85 COBOL Standard introduced a set of
  42.       intrinsic functions.  These functions are fully supported in
  43.       Microsoft COBOL 4.5. Functions are provided for Trigonometric,
  44.       Financial, Statistical and String handling.
  45.  
  46.    o  Floating Point
  47.  
  48.       COMP-1 (32 bit Real) and COMP-2 (64 bit Real) data types have been
  49.       added to this release of COBOL.  The syntax support is the same as
  50.       defined for IBM OSVS COBOL and IBM VS COBOL II, and an Intel Floating
  51.       Point Co-Processor will be used if available.
  52.  
  53.    o  Table Sort
  54.  
  55.       The SORT verb can now apply to a Data Division table, which will be
  56.       sorted in place.
  57.  
  58.    o  EXIT PERFORM
  59.  
  60.       Control of program flow is enhanced with a new EXIT PERFORM statement.
  61.  
  62.    o  'IF 78-level DEFINED' syntax for conditional compilation
  63.  
  64.    o  Support for X/Open XPG3 COBOL definition
  65.  
  66.    o  Compilation up to 10% faster
  67.  
  68.    o  General performance improvements in generated code
  69.  
  70.    o  Save and Restore Environment enables you to save the break-points and
  71.       monitors from one Animator session and reload them next time.
  72.  
  73.    o  Breakpoint when data value changes.
  74.  
  75.    o  Monitoring a subscripted item will follow a changing subscript.
  76.  
  77.    o  Data compression
  78.  
  79.       You can supply your own data compression routines, which can be
  80.       tuned to the data that will be in the file.
  81.  
  82.    o  OS/2 Database Manager (SQL) enhancements
  83.  
  84.       Support for: qualified host variables; more than 100 host variables in
  85.       one SQL statement; EXEC SQL WHENEVER SQLWARNING.
  86.  
  87.    o  Screens index program
  88.  
  89.       The Screens program will generate an index program which can be used
  90.       for simple data entry applications.
  91.  
  92.  
  93.   NEW DIRECTIVES
  94.  
  95.   These are the new compiler directives introduced in this product:
  96.  
  97.       ALIAS          Subscripts
  98.       BROWSE         Create .SBR file
  99.       CHECKDIV       Allow divide by zero
  100.       DEFAULTCALLS   CALL convention
  101.       DETECTLOCK     Detect record locks
  102.       DLL            DLL or EXE
  103.       FLAGAS         Show flags as errors etc.
  104.       HIDEMESSAGE    Set message to hide
  105.       INFORETURN     Info msg return value
  106.       INTLEVEL       Portability level
  107.       LOCKTYPE       Read locked records
  108.       MF(7)          Micro Focus COBOL syntax
  109.       SQLDB2         Mainframe compatibility
  110.       SQLFORMAT      Define date format
  111.       SQLPROT        Protect database
  112.       WRITETHROUGH   Unbuffered writes
  113.       XOPEN          X/Open
  114.  
  115.  
  116.   THE COBOL SOFTWARE
  117.  
  118.   Compatibility with Previous Releases
  119.   ====================================
  120.   This product is generally compatible with previous releases, However,
  121.   there are some differences. These are described in the ASCII text file,
  122.   CBL-CMPT.DOC, supplied with this product. Before you use this product with
  123.   programs created with earlier versions, we recommend that you read
  124.   CBL-CMPT.DOC.
  125.  
  126.  
  127.   Restrictions in the COBOL Software
  128.   ==================================
  129.    o  Cooperative Animation only allows 4 breakpoints to be set.
  130.  
  131.    o  In general, the components in this product support the High
  132.       Performance File System complex filenames. However, the directory
  133.       facility in some components will not work correctly when complex names
  134.       are present. Also, names are restricted to a maximum of 65 characters.
  135.  
  136.    o  NODYNAM currently impacts both CALL literal and CALL identifier. To
  137.       get mainframe-type link-edit, use NOLITLINK with DYNAM and LITLINK
  138.       with NODYNAM when compiling to OBJ.
  139.  
  140.    o  The ANIMATOR Do command will not work with:
  141.  
  142.        -  the CHAIN verb when parameters are supplied
  143.        -  CALL procedure-pointer
  144.        -  CALL ....  BY VALUE
  145.        -  CANCEL of nested program
  146.        -  EXIT PERFORM/PARAGRAPH/SECTION
  147.        -  intrinsic functions.
  148.  
  149.    o  The program-id of a called subprogram must be the same as the name
  150.       used for the .OBJ file created by the compiler. Otherwise, a new copy
  151.       will be loaded whenever the program is called.
  152.  
  153.    o  Under OS/2 you cannot redirect input to the compiler or Animator.
  154.  
  155.    o  On OS/2, any DLL that is to be loaded by the shared run-time that is
  156.       not specified with a path must exist on a path given in the COBDIR
  157.       environment variable, as well as on the OS/2 LIBPATH.
  158.  
  159.    o  EXTERNAL data items are limited to a maximum of 64K bytes each.
  160.  
  161.    o  The DISPLAY UPON PRINTER syntax does not work on OS/2.
  162.  
  163.    o  Any computation which has an intermediate result greater than 18
  164.       digits may give an incorrect final result. This will affect arithmetic
  165.       expressions such as those used in COMPUTE statements.
  166.  
  167.    o  Floating-point data is currently not supported in QuickWin applications.
  168.  
  169.    o  When interfacing with Microsoft C programs, the following C graphics
  170.       library routines should not be called as this will corrupt the COBOL
  171.       environment:
  172.  
  173.        -  _outtext
  174.        -  _outmem
  175.        -  _floodfill
  176.        -  any routine that uses floodfill where you specify the
  177.       _GFILLINTERIOR option (namely _ellipse and _pie)
  178.  
  179.    o  You should not use cross-session animation on a network server since
  180.       this can prevent cross-session animation operating on other machines
  181.       on the network.
  182.  
  183.    o  You cannot have more than ten files in the USING or GIVING phrase of a
  184.       MERGE statement.
  185.  
  186.    o  In VS COBOL II Releases 1 and 2, and OS/VS COBOL, the "PERFORM stack"
  187.       is preserved between calls to a program. Thus, on re-entry to the
  188.       program, the PERFORM state will be as it was when the program was last
  189.       exited. This means that the code to return to the PERFORM statement
  190.       which exists at the end of any piece of code that had been performed
  191.       but had not exited when the program itself was exited will remain
  192.       active, and may cause unexpected program flow when the program is
  193.       re-entered.
  194.  
  195.       This COBOL behaves the same way as VS COBOL II Release 3 and
  196.       initializes the PERFORM stack each time a program is called
  197.       irrespective of the existence of the VSC2(1), VSC2(2) or OSVS
  198.       directives.
  199.  
  200.    o  When interfacing with a C program, floating point items may only be
  201.       passed as BY REFERENCE parameters, not as BY VALUE or BY CONTENT
  202.       parameters.
  203.  
  204.  
  205.  
  206.   Restrictions in Related Software
  207.   ================================
  208.  
  209.   Novell(R) network
  210.   -----------------
  211.    o  When sharing files across a Novell network, it is essential that all
  212.       the workstations using the network are configured so that they do not
  213.       use local buffering (CACHE DATA BUFFERING). Failure to do this may
  214.       result in loss of data.
  215.  
  216.       Novell version 2.0A, and prior to 2.15 are all configured with local
  217.       buffering on by default. To disable this buffering, in version 2.0A
  218.       you require a patch from Novell. In other versions, insert the line:
  219.  
  220.       CACHE BUFFERS = 0
  221.  
  222.       into the file SHELL.CFG on each workstation.
  223.  
  224.    o  Use of the NETBIOS option on a Novell network can cause loss of data
  225.       on files shared across the network. (NETBIOS is activated by entering
  226.       the NETBIOS command after connecting to the network. To avoid loss of
  227.       data, do not use this command.)
  228.  
  229.    o  When creating multi-user programs to run on a Novell network, it is
  230.       necessary to ensure that all disk mapping assignments are beyond E:.
  231.       i.e. do not use assignments A: thru E:.
  232.  
  233.  
  234.  
  235.   DOCUMENTATION
  236.  
  237.   On-disk Documentation
  238.   =====================
  239.   The disks supplied with this product contain additional documentation.
  240.  
  241.   The following on-disk documents should be regarded as additional chapters,
  242.   or additions to chapters, in your Operating Guide:
  243.  
  244.       MFCOMPAT.DOC  - Compatibility with Micro Focus COBOL
  245.       OPTIMIZE.DOC  - Creating Optimized Programs
  246.       TIMEOUT.DOC   - Timeout Support in ACCEPT
  247.  
  248.  
  249.   Omissions and Errors
  250.   ====================
  251.   This section contains information that is either incorrect or missing from
  252.   your Microsoft COBOL manuals. This information is organized according
  253.   to the manual in which it appears. You may want to mark the changes in
  254.   your manuals.
  255.  
  256.  
  257.   Language Reference
  258.   ------------------
  259.   Page 5-24. There is an optional phrase within the WITH DUPLICATES phrase
  260.   of the ALTERNATE RECORD KEY clause of the SELECT statement for an indexed
  261.   file. Its syntax is:
  262.  
  263.       SUPPRESS  [WHEN]  { ZEROS         }
  264.             { SPACES        }
  265.             { [ALL] literal }
  266.  
  267.   SUPPRESS, ZEROS, SPACES, and ALL are all keywords.
  268.  
  269.  
  270.   Page 5-32. Insert a new General Rule (13a) between rules 13 and 14:
  271.  
  272.   "If a file is defined as EXTERNAL and the operating system file name is
  273.   assigned by means of a file name (for example, by use of either the
  274.   DYNAMIC directive or keyword, using data-name-1 in the SELECT/ASSIGN
  275.   statement, or using format 2 of the VALUE OF phrase of an FD), then the
  276.   following rules should be followed:
  277.  
  278.     1) An identifier with the same name should be used to contain the
  279.        physical file name in all programs which reference the file.
  280.  
  281.     2) Each definition of the identifier which contains the physical file
  282.        name should also contain the EXTERNAL attribute.
  283.  
  284.   Any violation of these rules will not be detected at compile time.
  285.   However, if any program in the run-unit violates these rules, the results
  286.   at run time are unpredictable. That is, they may or may not execute as
  287.   expected."
  288.  
  289.  
  290.   Page 5-83. After General Rule 27, add:
  291.  
  292.   "28. The I-O phrase permits the opening of a file for both input and
  293.   output operations (except for file with ORGANIZATION LINE SEQUENTIAL). If
  294.   the file does not exist it will be created and used as an empty file for
  295.   input unless NOT OPTIONAL was specified in the SELECT statement. An
  296.   attempt to WRITE it will cause an error."
  297.  
  298.  
  299.   Page 5-120. Add a new General Rule 13a:
  300.  
  301.   "The phrases ADVANCING PAGE and END-OF-PAGE must not both be specified in
  302.   a single WRITE statement."
  303.  
  304.  
  305.   Page 10-11, replace the entire second boxed extension with the following:
  306.  
  307.   "If a file is defined as EXTERNAL and the operating system file name is
  308.   assigned by means of a file name (for example,  by use of either the
  309.   DYNAMIC directive or keyword, using data-name-1 in the SELECT/ASSIGN
  310.   statement, or using format 2 of the VALUE OF phrase of an FD), then the
  311.   following rules should be followed:
  312.  
  313.     1) An identifier with the same name should be used to contain the
  314.        physical file name in all programs which reference the file.
  315.  
  316.     2) Each definition of the identifier which contains the physical file
  317.        name should also contain the EXTERNAL attribute.
  318.  
  319.   Any violation of these rules will not be detected at compile time.
  320.   However, if any program in the run-unit violates these rules, the results
  321.   at run time are unpredictable. That is, they may or may not execute as
  322.   expected."
  323.  
  324.  
  325.   Page 15-34, General Rule 4 of the FOREGROUND-COLOR clause. In the first
  326.   sentence, change "contains a BACKGROUND-COLOR clause" to "contains a
  327.   FOREGROUND-COLOR clause".
  328.  
  329.  
  330.   Page 16-43, before the description of the ORD-MAX function insert a
  331.   description of the ORD-MIN function. Its description is exactly the same
  332.   as that of ORD-MAX, but replacing "ORD-MAX" by "ORD-MIN", "maximum" by
  333.   "minimum" and "greatest" by "least" everywhere that they occur.
  334.  
  335.  
  336.   Operating Guide
  337.   ---------------
  338.  
  339.   General
  340.  
  341.       A number of the executable files are supplied with .PIF files for use
  342.       with Microsoft Windows 3.0 or later. Using these .PIF files, the
  343.       components of this system can be run as Windows applications, and can
  344.       be added to a group for direct execution from Program Manager. From
  345.       the DOS command line, these applications can be invoked using the
  346.       command
  347.  
  348.        WIN prog.PIF
  349.  
  350.       where prog is the name of the relevant component.
  351.  
  352.   Chapter 9 (Packaging and Shipping Applications):
  353.  
  354.       There is a module RMSTAT.OBJ, which must be linked into your
  355.       application if you want to get RM file statuses.
  356.  
  357.   Chapter 19 (SQL):
  358.  
  359.       There is no support for using COMP-1 items with SQL.
  360.  
  361.   Chapter 34 (Converting C Header Files with H2CPY)
  362.  
  363.       There is a utility called SPLIT78. It splits the constants file
  364.       produced by H2CPY into several files.
  365.  
  366.       It uses the first set of characters before the first hyphen to name
  367.       the files. For example, if OS2.78 contains:
  368.  
  369.        78 ABB-COLOR                         VALUE H"01".
  370.        78 ABB-BACK-COLOR                    VALUE H"02".
  371.        78 ABB-MIX-MODE                      VALUE H"04".
  372.        78 ABB-BACK-MIX-MODE                 VALUE H"08".
  373.        78 ABB-SET                           VALUE H"10".
  374.        78 ABB-SYMBOL                        VALUE H"20".
  375.        78 ABB-REF-POINT                     VALUE H"40".
  376.  
  377.        78 AF-CHAR                           VALUE H"01".
  378.        78 AF-VIRTUALKEY                     VALUE H"02".
  379.        78 AF-SCANCODE                       VALUE H"04".
  380.        78 AF-SHIFT                          VALUE H"08".
  381.        78 AF-CONTROL                        VALUE H"10".
  382.        78 AF-ALT                            VALUE H"20".
  383.        78 AF-LONEKEY                        VALUE H"40".
  384.        78 AF-SYSCOMMAND                     VALUE H"0100".
  385.        78 AF-HELP                           VALUE H"0200".
  386.  
  387.        78 HWND-DESKTOP                      VALUE 1.
  388.        78 HWND-OBJECT                       VALUE 2.
  389.        78 HWND-TOP                          VALUE 3.
  390.        78 HWND-BOTTOM                       VALUE 4.
  391.        78 HWND-THREADCAPTURE                VALUE 5.
  392.        78 HWND-PARENT                       VALUE 0.
  393.  
  394.       then typing the command, "SPLIT78 OS2.78" will create 3 files:
  395.  
  396.            ABB.78
  397.            AF.78
  398.         and    HWND.78
  399.  
  400.       The contents of OS2.78 will be unaffected. If any of the output files
  401.       already exist they will be extended, so make sure your working
  402.       directory contains no ".78" files other than the source file before
  403.       you enter the command SPLIT78.
  404.  
  405.   Appendix B (Compiler Directives):
  406.  
  407.       The default for the directive CHECKDIV is NOCHECKDIV, not CHECKDIV as
  408.       stated in the manuals.
  409.  
  410.       There is an additional directive FLAGCD. Its syntax is [NO] FLAGCD.
  411.       When it is set, selecting flagging for the dialect SAA, ANS85, OSVS or
  412.       VSC2 release 2 or 3 will not only flag syntax outside that dialect,
  413.       but will also flag any directive settings that cause behavior
  414.       incompatible with that dialect. The default is NOFLAGCD.
  415.  
  416.       There are two additional directives, HOST-NUMCOMPARE and ZWB which
  417.       direct the results of comparing a numeric display field with SPACE,
  418.       " " and "0". The directives are provided to ensure compatibility with
  419.       mainframe COBOL operation. If NOHOST-NUMCOMPARE or ZWB are specified,
  420.       the results of comparing are as now. If HOST-NUMCOMPARE and NOZWB are
  421.       specified together, the results are the exact opposite. Hence, if
  422.       PIC-9 contains spaces, the results of the comparison with SPACES, " "
  423.       and "0" are:
  424.                   PIC-9 = SPACE  PIC-9 = " "  PIC-9 = "0"
  425.       NOZWB and HOST-NUMCOMPARE       TRUE           TRUE         FALSE
  426.       ZWB or NOHOST-NUMCOMPARE        FALSE          FALSE        TRUE
  427.  
  428.       These results are the same independent of the setting of the F
  429.       run-time switch.
  430.  
  431.       There is an additional generator directive SIGNCOMPARE. Its syntax is
  432.       [NO] SIGNCOMPARE. When it is set in an EBCDIC program, it changes the
  433.       way some numeric comparisons are performed so that, for example, an
  434.       unsigned data item containing 1234 is equal to a signed data item
  435.       containing +1234. This does, however, cause these comparisons to be much
  436.       less efficient. The default is NOSIGNCOMPARE. If you are using an
  437.       add-on product, note that the behavior in intermediate code is the
  438.       same as you get in generated code with SIGNCOMPARE; thus with the
  439.       default setting of this directive, the behavior in intermediate code
  440.       and generated code is different.
  441.  
  442.       There is an error in the example given for STICKY-LINKAGE. The name
  443.       of the data item referenced in the Procedure Division code should be
  444.       HOURLY-RATE, not RATE.
  445.  
  446.       There is an additional directive ZEROLENGTHFALSE. Its syntax is
  447.       [NO] ZEROLENGTHFALSE. When it is set, all class tests of zero length
  448.       group items return false. Otherwise they all return true. The default
  449.       is NOZEROLENGTHFALSE. For conformance to ANSI and SAA you must set
  450.       ZEROLENGTHFALSE.
  451.  
  452.   Appendices C and D (COBOL System Library Routines)
  453.  
  454.       The following passage is relevant to both these appendices:
  455.  
  456.       The COBOL system library routines generally supply features that
  457.       cannot be accessed using COBOL syntax, such as operating system
  458.       functions. Under OS/2, many of the features can be accessed directly
  459.       by calling the OS/2 API functions. However, this ties the program to
  460.       OS/2, with DOS capability available only for those API calls which are
  461.       part of the Family API, and only then when the program is bound.
  462.  
  463.       Parameters to the call-by-name routines can be defined anywhere
  464.       provided they do not cross a segment boundary. (See the CHIP "16" and
  465.       FLAG-CHIP compiler directives.) Parameters to the call-by-number
  466.       routines must not be defined in the Linkage Section or Local-Storage
  467.       Section of your program, and must be in the first 64K of the Data
  468.       Division.
  469.  
  470.  
  471.   Error Messages
  472.   --------------
  473.  
  474.   Page 2-2. The reference to the E switch is only appropriate if you have
  475.   the Toolset or Workbench add-on products. Consequently, the effect of the
  476.   E switch is not documented in the Operating Guide as stated.
  477.  
  478.  
  479.   Pocket Guide
  480.   ------------
  481.  
  482.   Reserved Words List
  483.  
  484.       The words SECONDS is shown as a reserved word. This is incorrect.
  485.