Google
 

Trailing-Edge - PDP-10 Archives - BB-BT99T-BB_1990 - 10,7/compil/compil.hlp
There are 8 other files named compil.hlp in the archive. Click here to see a list.
COMPILE command

Function

     The COMPILE  command  produces  relocatable  binary  files  (.REL
     files)  and/or  compilation listings for specified source program
     files.  The system determines which language compiler to  use  by
     the  source  file  extension  or  by  switches you specify in the
     command string.  If you do not supply any switches in the command
     string,  but you do use a standard extension, the system uses the
     following compilers:

          Source File Extension    Compiler Used

          .ALG                     ALGOL compiler
          .BLI, .B10               BLISS-10 compiler
          .CBL                     COBOL compiler
          .F4 or .FOR              FORTRAN compiler
          .FAI                     FAIL compiler
          .MAC                     MACRO assembler
          .PAL                     PAL10 compiler
          .PAS                     Pascal compiler
          .P11                     MACY11 assembler
          .SAI                     SAIL compiler
          .SIM                     SIMULA compiler
          .SNO                     SNOBOL compiler

                                 NOTE

        The compiler cannot be changed with a switch,  but  it
        can  be  specified  with a switch when the source file
        has an unrecognizable or no extension.  If the  source
        file  has  a  non-standard  extension,  and you do not
        specify the compiler in a switch, FORTRAN is  used  as
        the  default  compiler.   For  help  on  standard file
        extensions, see the help file FILEXT.

     Usually, the system translates the source file  if  there  is  no
     corresponding  binary (.REL) file, or if the date and time of the
     source file is later than the date and time of the  binary  file.
     If the binary file is newer than the source file, the system does
     not generate a new .REL file.

     This command  runs  the  COMPIL  program,  which  interprets  the
     command before running the appropriate language compiler.

     FAIL, MACY11, SAIL, and SNOBOL are recognized as  compilers  only
     if   the   appropriate   assembly   switches   are  set  at  your
     installation.

     Each  time  you  issue  the  COMPILE,  LOAD,  EXECUTE,  or  DEBUG
     commands,  the  system remembers the command, with its arguments,
     in a temporary file on disk  or  in  TMPCOR  if  they  are  small
     enough.   When  you  issue  one  of  these  commands  without  an
     argument, it causes the system to use the argument saved  in  the
     temporary file.

     The COMPILE command accepts several command constructions:  the @
     construction  (indirect  commands),  the  +  construction,  the =
     construction, and the < > construction.  See the help file CONSTR
     for a description of each of these constructions.

Format

     COMPILE file-spec/switch,file-spec/switch,...

     Where:    file-spec is a single file specification or a string of
               file specifications, separated by commas.  The standard
               file specification consists of:  a device name, a  file
               name  (with  or  without an extension), and a directory
               name.  If you omit the file specification argument, the
               system  uses  the  argument  specified  in  a  previous
               COMPILE-class command, if possible.

                                        NOTE

                   Note that a maximum  of  150  processor  switch
                   characters can be passed to the compiler.

     You can use the following  switches  as  temporary  or  permanent
     switches.   For  more help on switches, see the help file SWITCH.
     Switches relevant to COMPILE follow; all  switches  allowed  with
     COMPILE can be used with LOAD, EXECUTE and DEBUG.

       Switch                            Function

     /ALGOL        Compiles with ALGOL.  Assumed for  files  with  the
                   .ALG extension.

     /BINARY       Generates a binary file  for  each  file  compiled.
                   The  file name of the binary file is .REL.  This is
                   the default action.

     /BLISS        Compiles the file with BLISS-10.  Assumed for files
                   with the extension of .B10 and .BLI.

     /C68          Compiles with COBOL-68.

     /C74          Compiles with COBOL-74.

     /COBOL        Compiles the file with COBOL.   Assumed  for  files
                   with the extension of .CBL.

     /COMPILE      Forces a compilation of this source  file  even  if
                   the  relocatable  binary  file  is newer.  Use this
                   switch to obtain an extra compilation (for example,
                   to obtain a listing of the compilation).  NOCOMPILE
                   is the default switch.

     /CREF         Produces a listing file on the disk for  each  file
                   compiled, for later processing by the CREF program.
                   The file extension of the  listing  file  is  .CRF.
                   The  file can then be listed with the CREF command.
                   With COBOL files, the CREF file is appended to  the
                   output  file;  additional  commands  are  needed to
                   obtain the cross-referenced file.

     /DDT          Loads the program debugger DDT with the file.

     /DEBUG:(arg, arg,...)
                   Passes the arguments  to  FORTRAN.   Refer  to  the
                   TOPS-10/TOPS-20 FORTRAN Language Manual.

     /DLIST        Creates a listing file with the extension .LST  and
                   stores  it  in  your  disk area.  You can have this
                   file printed on the line printer by using the PRINT
                   command.

     /F66          Applies FORTRAN-66 rules for DO loops and  EXTERNAL
                   statements.

     /FAIL         Assembles the file with FAIL.   Assumed  for  files
                   with the .FAI extension.

     /FORTRAN      Compiles the file with a FORTRAN compiler.  Assumed
                   for  files with either the extension of .F4 or .FOR
                   and for  all  files  with  unrecognizable  compiler
                   extensions, if FORTRAN is the standard compiler for
                   your system.  This switch is necessary if the  file
                   has   an   unrecognizable  compiler  extension  and
                   FORTRAN is not the standard compiler or is not  the
                   current default.

     /FORDDT       Loads the FORDDT debugger with the program.

     /FOROTS       Obsolete
     /FORSE

     /FUDGE:file   Creates a temporary file that contains the  library
                   file  name and the names of the .REL files produced
                   by the command string.  When you  issue  the  FUDGE
                   command,  PIP  reads  this  file  to  generate  the
                   library .REL file.  See the TOPS-10  MAKLIB  User's
                   Guide for information about library files.

                   The  argument  to  /FUDGE  is  the   library   file
                   specification.  If you omit the file extension, the
                   default is .REL.

                   This switch is permanent  (sticky).   That  is,  it
                   pertains  to  all  .REL  files  generated  by  this
                   command string.

     /GFLOAT       Indicates that double-precision numbers are  to  be
                   stored  in  G-floating  format.  This format has an
                   expanded exponent range.  This option is  available
                   on KL10 processors only.

     /K?10         Designates the machine on which  the  program  will
                   execute  after  it has been loaded.  The default is
                   the processor that is executing the command.  The ?
                   can  be  replaced  by  L  or  S.  To designate a KS
                   processor, use /KS10.

     /LIBRARY      Loads  the  program   in   library   search   mode.
                   (/LIBRARY is identical to /SEARCH.)

     /LINK         Obsolete

     /LIST         Prints the listing file on the line printer (LPT:).
                   If the line printer is spooled or available to your
                   job, the listing file is automatically printed.

     /LMAP:file    Produces a  loader  map  while  loading.   The  map
                   contains local symbols.

     /MACRO        Assembles the file with MACRO.  Assumed  for  files
                   with the extension of .MAC.

     /MACY11       Assembles the file with MACY11.  Assumed for  files
                   with the extension .P11.  MACY11 is recognized as a
                   compiler only if the appropriate assembly switch is
                   set.  This switch is not supported.

     /MAP:file     Produces a loader map while loading.   The  default
                   file name is MAP.MAP.

     /NEW          Runs the appropriate  language  compiler  from  the
                   experimental  library area [1,5] (device NEW:).  If
                   the compiler does not exist on device NEW:,  COMPIL
                   tries to obtain it from device SYS:.

     /NOBINARY     Does not generate binary files.  This switch,  when
                   combined  with the /CREF or /LIST switch, is useful
                   when  compiling   programs   solely   to   generate
                   listings.

     /NOCOMPILE    Compiles the source file if there is no relocatable
                   file   newer  than  the  source  file.   Note  that
                   /COMPILE always compiles, /REL never compiles,  and
                   /NOCOMPILE    (the    default    switch)   compiles
                   conditionally.

     /NODEBUG      Does not pass  previously  specified  arguments  to
                   FORTRAN.

     /NOLIST       Does not  generate  listing  files.   This  is  the
                   default action.  Complement to /LIST.

     /NOOPTIMIZE   Does not optimize the object source code.  This  is
                   the default.  Complement to /OPTIMIZE.

     /NOSEARCH     Does not load the program in library  search  mode.
                   Complement to /SEARCH.

     /OPTIMIZE     Optimizes the object code of a FORTRAN program.

     /OLD          Runs the appropriate  language  compiler  from  the
                   system library [1,3] of old programs (device OLD:).
                   If the compiler does  not  exist  on  device  OLD:,
                   COMPIL tries to obtain it from device SYS:.

     /PAL10        Assembles the file with PAL10.  Assumed  for  files
                   with the .PAL extension.

     /PASCAL       Compiles the file with Pascal.  Assumed  for  files
                   with the .PAS extension.

     /REL          Loads an existing .REL file rather than compiling a
                   new  one.   Refer  also to /COMPILE and /NOCOMPILE.
                   b.i-14 /SAIL Compiles the file with SAIL.   Assumed
                   for files with the .SAI extension.

     /SAVE         Saves the core image to disk in an executable  file
                   after it is loaded.

     /SEARCH       Loads the program in library search mode.  (/SEARCH
                   is identical to /LIBRARY.)

     /SELF         Runs the appropriate language compiler from  device
                   DSK:   instead  of  from the system library (device
                   SYS:).  This switch is useful if you keep a private
                   copy of a compiler in your own disk area.

     /SIMULA       Compiles the file with SIMULA.  Assumed  for  files
                   with the .SIM extension.

     /SNOBOL       Compiles the file with SNOBOL.  Assumed  for  files
                   with the extension .SNO.  SNOBOL is recognized as a
                   compiler only if the appropriate assembly switch is
                   set.  This switch is not supported.

     /SSAVE        Saves the core image in a sharable executable  file
                   after the program is loaded.

     /SYS          Compiles the program with the compiler  from  SYS:.
                   This is the default.

Characteristics

     Leaves your terminal at monitor level.

     Runs the appropriate language compiler, destroying your  original
     core image.

Restrictions

     You cannot use wildcard constructions with COMPILE.

     A language compiler appearing more  than  once  within  a  single
     command  string  cannot  access  more  than  one  disk area.  For
     example, the following is invalid:

     .COMPILE TESPRG.F10/NEW,SUBRTN.F10/SYS

     However, the following is valid:

     .COMPILE TESPRG.F10/NEW
     .COMPILE SUBRTN.F10/SYS

Examples

     1.  Compile PROG (with the null extension) with FORTRAN, TEST.MAC
         with  MACRO, and MANAGE (with the null extension) with MACRO.
         A listing file is generated for MANAGE.  The files  generated
         are PROG.REL, TEST.REL, MANAGE.REL, and MANAGE.LST.

         .COMPILE PROG,TEST.MAC,MANAGE/MACRO/LIST<RET>

         FORTRAN:  PROG
         MAIN
         MACRO:  TEST
         MANAGE
         EXIT

         .

     2.  Compile SIGN.MAC with MACRO, TABLES (with the null extension)
         with  FORTRAN,  and  MULTI.ALG with ALGOL.  Listing files are
         generated for SIGN.MAC and MULTI.ALG.

         .COMPILE/LIST SIGN.MAC,TABLES/NOLIST,MULTI.ALG<RET>

         MACRO:  SIGN
         FORTRAN:  TABLES
         MAIN
         ALGOL:  MULTI
         EXIT

         .

     3.  Compile the files DIVIDE, SUBTRC, and ADD  with  the  FORTRAN
         compiler,  even  if current .REL files exist.  Generate files
         to be processed by CREF.  The files generated are DIVIDE.CRF,
         DIVIDE.REL, SUBTRC.CRF, SUBTRC.REL, ADD.CRF and ADD.REL.

         .COMPILE/CREF/COMPILE DIVIDE,SUBTRC,ADD<RET>

         FORTRAN:  DIVIDE
         MAIN.
         FORTRAN:  SUBTRC
         MAIN.
         FORTRAN:  ADD
         MAIN.

         .

     4.  Compile the files  contained  in  the  command  file  LIBALL.
         Create  a  temporary  file  which  contains all the .REL file
         names and the library  file  name  (MONITR.REL).   The  FUDGE
         command  creates  the library file, MONITR.REL, with the .REL
         files in the same order as they were specified in the command
         file.

         .COMPILE/FUDGE:MONITR.REL@LIBALL<RET>

         FORTRAN:  DIVIDE
         MAIN.
         FORTRAN:  SUBTRC
         MAIN.
         FORTRAN:  ADD
         MAIN.

         .FUDGE<RET>

     5.  Compile and execute the program NUMBER.FOR.

         .COMPILE NUMB2.FOR<RET>

         FORTRAN:  NUMB2
         MAIN.

         .EXECUTE
         LINK:  LOADING
         [LNKXCT NUMB2 EXECUTION]
         DONE
         END OF EXECUTION
         CPU TIME:  0.12  ELAPSED TIME:  0.53
         EXIT

         .