File: external.txt

package info (click to toggle)
smarteiffel 1.1-11
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 12,288 kB
  • ctags: 40,785
  • sloc: ansic: 35,791; lisp: 4,036; sh: 1,783; java: 895; ruby: 613; python: 209; makefile: 115; csh: 78; cpp: 50
file content (66 lines) | stat: -rw-r--r-- 3,016 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
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
   Externals

   Here  is the information you need if you want to call C code, C++ code
   as  well as Java code from your Eiffel code (to call an Eiffel feature
   from C, C++ or Java see [1]cecil documentation).

   Below   is   the   current   list  of  SmartEiffel  external  language
   specifications.

   external "C"

   The  most common way to call external C code from Eiffel is to use the
   external  "C"  feature definition as described in the book "Eiffel The
   Language".  The best is to start to browse examples of the SmartEiffel
   distribution   in  directory  tutorial/external/C  where  you'll  find
   external "C", external "C inline", external "C macro" examples.

   external "C++"

   The  most  common  way to call external C++ code from Eiffel is to use
   the  external  C++ feature definition as described in the book "Eiffel
   The  Language".  The  best  is  to  start  to  browse  examples of the
   SmartEiffel  distribution  in  directory  tutorial/external/C++  where
   you'll find external "C++" examples.

   external "Java"

   A  brand  new  interface  to call Java method or Java static method is
   also  available.  Obviously, this one is only supported when using the
   compile_to_jvm  command  (conversely,  previous one are only supported
   when  using  the compile_to_c command). Again, and especially for this
   brand  new  one,  the  best  is  to  start  to  browse examples of the
   SmartEiffel distribution in directory tutorial/external/Java.

   external "SmartEiffel"

   This  external  specification  is reserved to the SmartEiffel 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 class
   INTEGER  is  directly mapped as C '+' by compile_to_c and mapped as an
   iadd JVM byte-code by compile_to_jvm.

   Inlining C Code (or assembly code)

   Another  way  to  call  C  code  from Eiffel is to use "c_inline_c" or
   "c_inline_h"  as  defined  in  our  GENERAL  class.  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 in lieu.
   Using  c_inline_[c/h]  also  implies  you  do  know exactly the C code
   SmartEiffel  produces.  For portability, it is also much better to use
   previous solutions.
   People  who  tinker  with  the  C  code  generated by SmartEiffel, not
   limiting  themselves  to  the Cecil and/or external interfaces, should
   also  read  [2]this  page  about  the C code generated by SmartEiffel,
   Otherwise they might get into trouble.

                                   [Line]
             Copyright  Dominique COLNET and Suzanne COLLIN -
                         [3]<SmartEiffel@loria.fr>
                Last modified: Tue Feb 11 12:15:02 CET 2003

References

   1. file://localhost/users/miro/colnet/SmartEiffel/man/cecil.html
   2. file://localhost/users/miro/colnet/SmartEiffel/man/c_code.html
   3. mailto:SmartEiffel@loria.fr