Mercurial > hg > truffle
annotate truffle/com.oracle.truffle.api.interop/src/com/oracle/truffle/api/interop/package-info.java @ 22494:cff4a9d3e72a
Enumerating allowed interop types
author | Jaroslav Tulach <jaroslav.tulach@oracle.com> |
---|---|
date | Mon, 14 Dec 2015 08:46:35 +0100 |
parents | 0bd14859636f |
children |
rev | line source |
---|---|
21770
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
1 /* |
22004
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
2 * Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
21770
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
4 * |
22004
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
5 * This code is free software; you can redistribute it and/or modify it |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
6 * under the terms of the GNU General Public License version 2 only, as |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
7 * published by the Free Software Foundation. Oracle designates this |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
8 * particular file as subject to the "Classpath" exception as provided |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
9 * by Oracle in the LICENSE file that accompanied this code. |
21770
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
10 * |
22004
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
11 * This code is distributed in the hope that it will be useful, but WITHOUT |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
14 * version 2 for more details (a copy is included in the LICENSE file that |
21770
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
15 * accompanied this code). |
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
16 * |
22004
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
17 * You should have received a copy of the GNU General Public License version |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
18 * 2 along with this work; if not, write to the Free Software Foundation, |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
21770
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
20 * |
22004
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
22 * or visit www.oracle.com if you need additional information or have any |
11e0412c5b0e
Make headers valid for checkstyle again.
Christian Humer <christian.humer@gmail.com>
parents:
22003
diff
changeset
|
23 * questions. |
21770
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
24 */ |
22061
0bd14859636f
interop API is stable
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22004
diff
changeset
|
25 |
0bd14859636f
interop API is stable
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22004
diff
changeset
|
26 /* |
0bd14859636f
interop API is stable
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22004
diff
changeset
|
27 @ApiInfo( |
0bd14859636f
interop API is stable
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22004
diff
changeset
|
28 group="Stable" |
0bd14859636f
interop API is stable
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22004
diff
changeset
|
29 ) |
0bd14859636f
interop API is stable
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22004
diff
changeset
|
30 */ |
0bd14859636f
interop API is stable
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22004
diff
changeset
|
31 |
21770
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
32 /** |
21775
b0df81ea5b20
use qualified references in package-info.java javadoc to accommodate limitation in Eclipse
Doug Simon <doug.simon@oracle.com>
parents:
21770
diff
changeset
|
33 * This package provides inter-operability between different |
b0df81ea5b20
use qualified references in package-info.java javadoc to accommodate limitation in Eclipse
Doug Simon <doug.simon@oracle.com>
parents:
21770
diff
changeset
|
34 * {@link com.oracle.truffle.api.TruffleLanguage Truffle languages}. |
21770
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
35 * <p> |
22494
cff4a9d3e72a
Enumerating allowed interop types
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22061
diff
changeset
|
36 * Languages can exchange primitive Java type wrapper objects (e.g., |
cff4a9d3e72a
Enumerating allowed interop types
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22061
diff
changeset
|
37 * {@link java.lang.Byte}, |
cff4a9d3e72a
Enumerating allowed interop types
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22061
diff
changeset
|
38 * {@link java.lang.Short}, |
cff4a9d3e72a
Enumerating allowed interop types
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22061
diff
changeset
|
39 * {@link java.lang.Integer}, |
cff4a9d3e72a
Enumerating allowed interop types
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22061
diff
changeset
|
40 * {@link java.lang.Long}, |
cff4a9d3e72a
Enumerating allowed interop types
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22061
diff
changeset
|
41 * {@link java.lang.Float}, |
cff4a9d3e72a
Enumerating allowed interop types
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22061
diff
changeset
|
42 * {@link java.lang.Double}, |
cff4a9d3e72a
Enumerating allowed interop types
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22061
diff
changeset
|
43 * {@link java.lang.Character}, |
cff4a9d3e72a
Enumerating allowed interop types
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22061
diff
changeset
|
44 * {@link java.lang.Boolean}, |
cff4a9d3e72a
Enumerating allowed interop types
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22061
diff
changeset
|
45 * and {@link java.lang.String}) |
cff4a9d3e72a
Enumerating allowed interop types
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
22061
diff
changeset
|
46 * as well as any type implementing |
22003
5bc7f7b867ab
Making debugger always on for each TruffleVM execution. Introducing EventConsumer to process such debugger events. Requesting each RootNode to be associated with a TruffleLanguage, so debugger can find out proper context for each Node where executions gets suspended.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
21951
diff
changeset
|
47 * {@link com.oracle.truffle.api.interop.TruffleObject}. Foreign objects are precisely those |
5bc7f7b867ab
Making debugger always on for each TruffleVM execution. Introducing EventConsumer to process such debugger events. Requesting each RootNode to be associated with a TruffleLanguage, so debugger can find out proper context for each Node where executions gets suspended.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
21951
diff
changeset
|
48 * implementing {@link com.oracle.truffle.api.interop.TruffleObject}. |
21770
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
49 * <p> |
22003
5bc7f7b867ab
Making debugger always on for each TruffleVM execution. Introducing EventConsumer to process such debugger events. Requesting each RootNode to be associated with a TruffleLanguage, so debugger can find out proper context for each Node where executions gets suspended.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
21951
diff
changeset
|
50 * To use a {@link com.oracle.truffle.api.interop.TruffleObject} from a different language, you need |
5bc7f7b867ab
Making debugger always on for each TruffleVM execution. Introducing EventConsumer to process such debugger events. Requesting each RootNode to be associated with a TruffleLanguage, so debugger can find out proper context for each Node where executions gets suspended.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
21951
diff
changeset
|
51 * to ask the language to build appropriate AST for a given |
21775
b0df81ea5b20
use qualified references in package-info.java javadoc to accommodate limitation in Eclipse
Doug Simon <doug.simon@oracle.com>
parents:
21770
diff
changeset
|
52 * {@link com.oracle.truffle.api.interop.Message} with |
22003
5bc7f7b867ab
Making debugger always on for each TruffleVM execution. Introducing EventConsumer to process such debugger events. Requesting each RootNode to be associated with a TruffleLanguage, so debugger can find out proper context for each Node where executions gets suspended.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
21951
diff
changeset
|
53 * {@link com.oracle.truffle.api.interop.Message#createNode}. The message can then be executed with |
5bc7f7b867ab
Making debugger always on for each TruffleVM execution. Introducing EventConsumer to process such debugger events. Requesting each RootNode to be associated with a TruffleLanguage, so debugger can find out proper context for each Node where executions gets suspended.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
21951
diff
changeset
|
54 * {@link com.oracle.truffle.api.interop.ForeignAccess#execute}. |
21770
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
55 */ |
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
56 package com.oracle.truffle.api.interop; |
c76742cc2c6f
Polishing inter-operability APIs: Exposing only Message, TruffleObject and ForeignAccess-related classes.
Jaroslav Tulach <jaroslav.tulach@oracle.com>
parents:
diff
changeset
|
57 |