Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[truffle] Implement nqp::iscont and _<i n s>
- Loading branch information
1 parent
ed653e1
commit c893f05
Showing
6 changed files
with
119 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
24 changes: 24 additions & 0 deletions
24
src/vm/jvm/runtime/org/perl6/nqp/truffle/nodes/expression/NQPIscontIntNode.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
package org.perl6.nqp.truffle.nodes.expression; | ||
import com.oracle.truffle.api.frame.VirtualFrame; | ||
import com.oracle.truffle.api.nodes.NodeInfo; | ||
import org.perl6.nqp.sixmodel.SixModelObject; | ||
import org.perl6.nqp.sixmodel.StorageSpec; | ||
import org.perl6.nqp.truffle.nodes.NQPNode; | ||
import org.perl6.nqp.truffle.nodes.NQPIntNode; | ||
import org.perl6.nqp.truffle.runtime.ContainerOps; | ||
import org.perl6.nqp.dsl.Deserializer; | ||
|
||
@NodeInfo(shortName = "iscont_i") | ||
public final class NQPIscontIntNode extends NQPIntNode { | ||
@Child private NQPNode argNode; | ||
|
||
@Deserializer | ||
public NQPIscontIntNode(NQPNode argNode) { | ||
this.argNode = argNode; | ||
} | ||
|
||
@Override | ||
public long executeInt(VirtualFrame frame) { | ||
return ContainerOps.getContainerPrimitive((SixModelObject)argNode.execute(frame)) == StorageSpec.BP_INT ? 1 : 0; | ||
} | ||
} |
23 changes: 23 additions & 0 deletions
23
src/vm/jvm/runtime/org/perl6/nqp/truffle/nodes/expression/NQPIscontNode.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
package org.perl6.nqp.truffle.nodes.expression; | ||
import com.oracle.truffle.api.frame.VirtualFrame; | ||
import com.oracle.truffle.api.nodes.NodeInfo; | ||
import org.perl6.nqp.sixmodel.SixModelObject; | ||
import org.perl6.nqp.truffle.nodes.NQPNode; | ||
import org.perl6.nqp.truffle.nodes.NQPIntNode; | ||
import org.perl6.nqp.dsl.Deserializer; | ||
|
||
@NodeInfo(shortName = "iscont") | ||
public final class NQPIscontNode extends NQPIntNode { | ||
@Child private NQPNode argNode; | ||
|
||
@Deserializer | ||
public NQPIscontNode(NQPNode argNode) { | ||
this.argNode = argNode; | ||
} | ||
|
||
@Override | ||
public long executeInt(VirtualFrame frame) { | ||
SixModelObject obj = (SixModelObject)argNode.execute(frame); | ||
return obj == null || obj.st.ContainerSpec == null ? 0 : 1; | ||
} | ||
} |
24 changes: 24 additions & 0 deletions
24
src/vm/jvm/runtime/org/perl6/nqp/truffle/nodes/expression/NQPIscontNumNode.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
package org.perl6.nqp.truffle.nodes.expression; | ||
import com.oracle.truffle.api.frame.VirtualFrame; | ||
import com.oracle.truffle.api.nodes.NodeInfo; | ||
import org.perl6.nqp.sixmodel.SixModelObject; | ||
import org.perl6.nqp.sixmodel.StorageSpec; | ||
import org.perl6.nqp.truffle.nodes.NQPNode; | ||
import org.perl6.nqp.truffle.nodes.NQPIntNode; | ||
import org.perl6.nqp.truffle.runtime.ContainerOps; | ||
import org.perl6.nqp.dsl.Deserializer; | ||
|
||
@NodeInfo(shortName = "iscont_n") | ||
public final class NQPIscontNumNode extends NQPIntNode { | ||
@Child private NQPNode argNode; | ||
|
||
@Deserializer | ||
public NQPIscontNumNode(NQPNode argNode) { | ||
this.argNode = argNode; | ||
} | ||
|
||
@Override | ||
public long executeInt(VirtualFrame frame) { | ||
return ContainerOps.getContainerPrimitive((SixModelObject)argNode.execute(frame)) == StorageSpec.BP_NUM ? 1 : 0; | ||
} | ||
} |
24 changes: 24 additions & 0 deletions
24
src/vm/jvm/runtime/org/perl6/nqp/truffle/nodes/expression/NQPIscontStrNode.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
package org.perl6.nqp.truffle.nodes.expression; | ||
import com.oracle.truffle.api.frame.VirtualFrame; | ||
import com.oracle.truffle.api.nodes.NodeInfo; | ||
import org.perl6.nqp.sixmodel.SixModelObject; | ||
import org.perl6.nqp.sixmodel.StorageSpec; | ||
import org.perl6.nqp.truffle.nodes.NQPNode; | ||
import org.perl6.nqp.truffle.nodes.NQPIntNode; | ||
import org.perl6.nqp.truffle.runtime.ContainerOps; | ||
import org.perl6.nqp.dsl.Deserializer; | ||
|
||
@NodeInfo(shortName = "iscont_s") | ||
public final class NQPIscontStrNode extends NQPIntNode { | ||
@Child private NQPNode argNode; | ||
|
||
@Deserializer | ||
public NQPIscontStrNode(NQPNode argNode) { | ||
this.argNode = argNode; | ||
} | ||
|
||
@Override | ||
public long executeInt(VirtualFrame frame) { | ||
return ContainerOps.getContainerPrimitive((SixModelObject)argNode.execute(frame)) == StorageSpec.BP_STR ? 1 : 0; | ||
} | ||
} |
20 changes: 20 additions & 0 deletions
20
src/vm/jvm/runtime/org/perl6/nqp/truffle/runtime/ContainerOps.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
package org.perl6.nqp.truffle.runtime; | ||
import com.oracle.truffle.api.CompilerDirectives.TruffleBoundary; | ||
import org.perl6.nqp.sixmodel.ContainerSpec; | ||
import org.perl6.nqp.sixmodel.NativeRefContainerSpec; | ||
import org.perl6.nqp.sixmodel.StorageSpec; | ||
import org.perl6.nqp.sixmodel.SixModelObject; | ||
import org.perl6.nqp.sixmodel.TypeObject; | ||
import org.perl6.nqp.sixmodel.reprs.NativeRefREPRData; | ||
|
||
public class ContainerOps { | ||
@TruffleBoundary | ||
public static short getContainerPrimitive(SixModelObject obj) { | ||
if (obj != null && !(obj instanceof TypeObject)) { | ||
ContainerSpec cs = obj.st.ContainerSpec; | ||
if (cs instanceof NativeRefContainerSpec) | ||
return ((NativeRefREPRData)(obj.st.REPRData)).primitive_type; | ||
} | ||
return StorageSpec.BP_NONE; | ||
} | ||
} |