⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 acd.1

📁 操作系统设计与实现源码
💻 1
📖 第 1 页 / 共 2 页
字号:


ACD(1)                    Minix Programmer's Manual                     ACD(1)


NAME
     acd - a compiler driver

SYNOPSIS
     acd -v[n] -vn[n] -name name -descr descr -T dir [arg ...]

DESCRIPTION
     Acd is a compiler driver, a program that calls the  several  passes  that
     are needed to compile a source file.  It keeps track of all the temporary
     files used between the passes.  It also  defines  the  interface  of  the
     compiler, the options the user gets to see.

     This text only describes acd itself, it says nothing about the  different
     options the C-compiler accepts.  (It has nothing to do with any language,
     other than being a tool to give a compiler a user interface.)

OPTIONS
     Acd itself takes five options:

     -v[n]
          Sets the diagnostic level to n (by default 2).  The higher n is, the
          more  output  acd  generates:  -v0 does not produce any output.  -v1
          prints the basenames of the programs called.  -v2 prints  names  and
          arguments  of  the programs called.  -v3 shows the commands executed
          from the description file too.  -v4 shows the program read from  the
          description file too.  Levels 3 and 4 use backspace overstrikes that
          look good when viewing the output with a smart pager.

     -vn[n]
          Like -v except that no command is  executed.   The  driver  is  just
          play-acting.

     -name name
          Acd is normally linked to the name the compiler is to be called with
          by  the user.  The basename of this, say cc, is the call name of the
          driver.  It plays a role in selecting the proper  description  file.
          With  the  -name  option  one can change this.  Acd -name cc has the
          same effect as calling the program as cc.

     -descr descr
          Allows one to choose the pass description file of  the  driver.   By
          default descr is the same as name, the call name of the program.  If
          descr  doesn't  start  with  /,   ./,   or   ../   then   the   file
          /usr/lib/descr/descr  will  be  used  for the description, otherwise
          descr itself.  Thus cc -descr newcc  calls  the  C-compiler  with  a
          different description file without changing the call name.  Finally,
          if descr is "-", standard input is read.  (The default lib directory
          /usr/lib,  may  be  changed to dir at compile time by -DLIB=\"dir\".
          The default descr may  be  set  with  -DDESCR=\"descr\"  for  simple
          installations on a system without symlinks.)


                                                                             1



ACD(1)                    Minix Programmer's Manual                     ACD(1)


     -T dir
          Temporary files are made in /tmp by default, which may be overridden
          by  the  environment variable TMPDIR, which may be overridden by the
          -T option.

THE DESCRIPTION FILE
     The description file is a program interpreted  by  the  driver.   It  has
     variables,  lists  of  files,  argument  parsing  commands, and rules for
     transforming input files.

  Syntax
     There are four simple objects:

          Words, Substitutions, Letters, and Operators.

     And there are two ways to group objects:

          Lists, forming sequences of anything but letters,

          Strings, forming sequences of anything but Words and Operators.

     Each object has the following syntax:

     Words
          They are sequences of characters, like cc, -I/usr/include, /lib/cpp.
          No  whitespace  and  no special characters.  The backslash character
          (\)  may  be  used  to  make  special  characters   common,   except
          whitespace.   A  backslash  followed  by  whitespace  is  completely
          removed from the input.  The sequence \n is changed to a newline.

     Substitutions
          A substitution (henceforth called 'subst') is formed with a $,  e.g.
          $opt,  $PATH,  ${lib}, $*.  The variable name after the $ is made of
          letters, digits and  underscores,  or  any  sequence  of  characters
          between parentheses or braces, or a single other character.  A subst
          indicates that the value of the named variable must  be  substituted
          in the list or string when fully evaluated.

     Letters
          Letters are the single characters that would make up a word.

     Operators
          The characters =, +, -, *, <, and > are the  operators.   The  first
          four  must  be  surrounded  by  whitespace if they are to be seen as
          special (they are often used in arguments).  The last two are always
          special.

     Lists
          One line of objects in the  description  file  forms  a  list.   Put
          parentheses  around  it  and  you  have  a  sublist.   The values of


                                                                             2



ACD(1)                    Minix Programmer's Manual                     ACD(1)


          variables are lists.

     Strings
          Anything that is not yet a word is a string.  All it needs  is  that
          the  substs in it are evaluated, e.g.  $LIBPATH/lib$key.a.  A single
          subst doesn't make a string, it expands to  a  list.   You  need  at
          least one letter or other subst next to it.  Strings (and words) may
          also be formed by enclosing them in double quotes.   Only  \  and  $
          keep their special meaning within quotes.

  Evaluation
     One thing has to be carefully understood: Substitutions are delayed until
     the  last  possible moment, and description files make heavy use of this.
     Only if a subst is tainted,  either  because  its  variable  is  declared
     local,  or  because  a  subst  in  its variable's value is tainted, is it
     immediately substituted.  So if a list is assigned  to  a  variable  then
     this  list is only checked for tainted substs.  Those substs are replaced
     by the value of their variable.  This is called partial evaluation.

     Full evaluation expands all substs,  the  list  is  flattened,  i.e.  all
     parentheses are removed from sublists.

     Implosive evaluation is the last that has to be done to a list before  it
     can  be  used  as  a command to execute.  The substs within a string have
     been evaluated to lists after full expansion, but a string must be turned
     into  a  single word, not a list.  To make this happen, a string is first
     exploded to all possible combinations of words choosing one member of the
     lists within the string.  These words are tried one by one to see if they
     exist as a file.  The first one that exists is taken, if none exists than
     the  first  choice  is  used.  As an example, assume LIBPATH equals (/lib
     /usr/lib), key is (c) and key happens to be local.  Then we have:

          "$LIBPATH/lib$key.a"

     before evaluation,

          "$LIBPATH/lib(c).a"

     after partial evaluation,

          "(/lib/libc.a /usr/lib/libc.a)"

     after full evaluation, and finally

          /usr/lib/libc.a

     after implosion, if the file exists.





                                                                             3



ACD(1)                    Minix Programmer's Manual                     ACD(1)


  Operators
     The operators modify the way evaluation is done  and  perform  a  special
     function on a list:

     *    Forces full evaluation on all the list elements following  it.   Use
          it  to  force substitution of the current value of a variable.  This
          is the only operator that forces immediate evaluation.

     +    When a + exists in a list that is  fully  evaluated,  then  all  the
          elements  before the + are imploded and all elements after the + are
          imploded and added to the list if they are not already in the  list.
          So  this  operator  can be used either for set addition, or to force
          implosive expansion within a sublist.

     -    Like +, except that elements after the - are removed from the list.

     The set operators can be used to gather options that exclude  each  other
     or for their side effect of implosive expansion.  You may want to write:

          cpp -I$LIBPATH/include

     to call cpp with an extra include directory,  but  $LIBPATH  is  expanded
     using  a  filename  starting  with -I so this won't work.  Given that any
     problem in Computer  Science  can  be  solved  with  an  extra  level  of
     indirection, use this instead:

          cpp -I$INCLUDE
          INCLUDE = $LIBPATH/include +

  Special Variables
     There are three special variables used in a description  file:   $*,  $<,
     and  $>.   These  variables  are always local and mostly read-only.  They
     will be explained later.

  A Program
     The lists in a description file form a program that is executed from  the
     first  to the last list.  The first word in a list may be recognized as a
     builtin command (only if the first list element is indeed simply a word.)
     If  it  is  not a builtin command then the list is imploded and used as a
     UNIX command with arguments.

     Indentation (by tabs or spaces) is not just makeup for a program, but are
     used  to group lines together.  Some builtin commands need a body.  These
     bodies are simply lines at a deeper indentation.

     Empty lines are not ignored either, they have the same indentation  level
     as  the line before it.  Comments (starting with a # and ending at end of
     line) have an indentation of their own and can be used as null commands.




                                                                             4



ACD(1)                    Minix Programmer's Manual                     ACD(1)


     Acd will complain about unexpected indentation shifts and  empty  bodies.
     Commands  can share the same body by placing them at the same indentation
     level before the indented body.  They are then "guards" to the same body,
     and  are  tried  one  by  one until one succeeds, after which the body is
     executed.

     Semicolons may be used to separate commands  instead  of  newlines.   The
     commands are then all at the indentation level of the first.

  Execution phases
     The driver runs in three phases: Initialization, Argument  scanning,  and
     Compilation.   Not  all  commands  work  in  all phases.  This is further
     explained below.

  The Commands
     The commands accept arguments that are usually generic  expressions  that
     implode  to  a  word  or  a list of words.  When var is specified, then a
     single word or subst needs to be given, so an assignment  can  be  either
     name = value, or $name = value.

     var = expr ...
          The partially evaluated list of  expressions  is  assigned  to  var.
          During  the  evaluation  is  var  marked  as  local,  and  after the
          assignment set from undefined to defined.

     unset var
          Var is set to null and is marked as undefined.

     import var
          If var is defined in the environment of acd then it is  assigned  to
          var.  The environment variable is split into words at whitespace and
          colons.  Empty space between two colons (::)  is changed to a dot.

     mktemp var [suffix]
          Assigns to var the name of a new temporary file,  usually  something
          like  /tmp/acd12345x.  If suffix is present then it will be added to
          the temporary file's name.  (Use it because  some  programs  require
          it,  or  just  because it looks good.)  Acd remembers this file, and
          will delete it as soon as you stop referencing it.

     temporary word
          Mark the file named by word as a temporary file.  You have  to  make
          sure  that the name is stored in some list in imploded form, and not
          just temporarily created when word is  evaluated,  because  then  it
          will be immediately removed and forgotten.

     stop suffix
          Sets the target suffix for the compilation  phase.   Something  like
          stop  .o  means  that  the  source  files must be compiled to object
          files.  At least one  stop  command  must  be  executed  before  the


                                                                             5



ACD(1)                    Minix Programmer's Manual                     ACD(1)


          compilation  phase  begins.   It  may  not  be  changed  during  the
          compilation  phase.   (Note:  There  is no restriction on suffix, it
          need not start with a dot.)

     treat file suffix
          Marks the file as having the given suffix  for  the  compile  phase.
          Useful for sending a -l option directly to the loader by treating it
          as having the .a suffix.

     numeric arg
          Checks if arg is a number.  If not then acd will exit  with  a  nice
          error message.

     error expr ...
          Makes the driver print the error message expr ... and exit.

     if expr = expr
          If tests if the two expressions are equal using set comparison, i.e.
          each   expression   should  contain  all  the  words  in  the  other
          expression.  If the test succeeds then the if-body is executed.

     ifdef var
          Executes the ifdef-body if var is defined.

     ifndef var
          Executes the ifndef-body if var is undefined.

     iftemp arg
          Executes the iftemp-body if arg is a temporary file.  Use it when  a
          command  has the same file as input and output and you don't want to
          clobber the source file:

               transform .o .o
                       iftemp $*
                               $> = $*
                       else
                               cp $* $>
                       optimize $>

     ifhash arg
          Executes the ifhash-body if arg is an existing file with  a  '#'  as
          the very first character.  This usually indicates that the file must
          be pre-processed:

               transform .s .o
                       ifhash $*
                               mktemp ASM .s
                               $CPP $* > $ASM
                       else
                               ASM = $*


                                                                             6



ACD(1)                    Minix Programmer's Manual                     ACD(1)


                       $AS -o $> $ASM
                       unset ASM

     else Executes the else-body if  the  last  executed  if,  ifdef,  ifndef,
          iftemp,  or  ifhash  was  unsuccessful.   Note  that  else  need not
          immediately follow an if, but you are advised not  to  make  use  of
          this.  It is a "feature" that may not last.

     apply suffix1 suffix2
          Executed inside a transform rule body to transform  the  input  file
          according  to  another  transform  rule that has the given input and
          output suffixes.  The file under $* will  be  replaced  by  the  new
          file.   So if there is a .c .i preprocessor rule then the example of
          ifhash can be replaced by:

               transform .s .o
                       ifhash $*
                               apply .c .i
                       $AS -o $> $*

     include descr
          Reads another description file and replaces  the  include  with  it.
          Execution  continues  with  the  first list in the new program.  The
          search for descr is the same as used for  the  -descr  option.   Use
          include to switch in different front ends or back ends, or to call a

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -