
                                 Externals
                                      
   Here is the information you need if you want to call C or Java code
   from Eiffel code (to call Eiffel feature from C or Java see [1]cecil
   file).
   
   The most common way to call external code from Eiffel is to use the
   external feature definition as described in the book "Eiffel The
   Language". The best is to start to browse examples of the SmallEiffel
   distribution in directory tutorial/external.
   
   Below is the current list of SmallEiffel external specifications.
   
   external "SmallEiffel"
   
   This external specification is reserved to the SmallEiffel compiler
   itself. Do not use it. Such a feature is directly supported both by
   compile_to_c and compile_to_jvm. For example, infix "+" of INTEGER is
   direcly mapped as C '+' by compile_to_c. For the same infix "+",
   command compile_to_jvm produce the appropriate Java virtual machine
   byte code.
   
   external "JVM_invokestatic"
   
   Calling a Java static method. As it is a static Java call, the Eiffel
   receiver is not used. The "alias" field of the feature is used to
   indicate the Java class, the Java function name and the corresponding
   Java bytecode descriptor. Syntax to use in the alias string is :
          alias "<JavaClassPath>.<MethodName> <Descriptor>"
          
   A dot is the separator between <JavaClassPath> and <MethodName>.
   A blank character is the separator between <MethodName> and
   <Descriptor>.
   The <JavaClassPath> uses the JVM internal notation as described in
   JVMS(*). For example, when one wants to use java.lang.Math, the
   <JavaClassPath> is "java/lang/Math". The <MethodName> gives the Java
   method name. The <Descriptor> gives the internal Java bytecode
   descriptor as described in JVMS(*).
(*) - JVMS -
   "The Java Virtual Machine Specification",
   Tim Lindholm and Frank Yellin, The Java Series,
   Addison-Wesley, ISBN 0-201-63452-X.

   external "JVM_invokevirtual"
   
   Calling a Java virtual method. As for "JVM_invokestatic", the alias
   string gives all needed information to call the virtual function. The
   Current Eiffel target is not used (only arguments and the result are
   considered).
   
   Inlining C code
   
   Another way to call C code from Eiffel is to use "c_inline_c" or
   "c_inline_h" as defined in GENERAL. The argument of "c_inline_c" (or
   "c_inline_h") must always be a manifest string which may contains the
   C code you want to put inlieu.
   Using c_inline_[c/h] also implies you do know exactly the C code
   SmallEiffel produces. For portability, it is also much better to use
   previous solutions.
   People who tinker with the C code generated by SmallEiffel, not
   limiting themselves to the Cecil and/or external interfaces, should
   also read [2]this page about the C code generated by SmallEiffel,
   Otherwise they might get into trouble.
   
                                   [Line]
             Copyright  Dominique COLNET and Suzanne COLLIN -
                         [3]<SmallEiffel@loria.fr>
                Last modified: Thu Feb 14 21:42:54 MET 2002 

References

   1. file://localhost/home/colnet/SmallEiffel/man/man/cecil.html
   2. file://localhost/home/colnet/SmallEiffel/man/man/c_code.html
   3. mailto:SmallEiffel@loria.fr
