[
https://issues.apache.org/jira/browse/PYLUCENE-21?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Craig Rickle updated PYLUCENE-21:
---------------------------------
Very much appreciate your response. I did exclude my jcc invocation. This is
a snapshot, where I paired down the pylucene Makefile and adapted to a simple
Maven archetype generated project:
python -m jcc.__main__ --arch x86_64 --jar
/Users/crickle/jcc/jcc-hello/target/jcc-hello-1.0-SNAPSHOT.jar --rename
home.App\$Embedded=AppEmbedded --package java.lang java.lang.System
java.lang.Runtime java.lang.IllegalStateException
java.lang.IndexOutOfBoundsException --package java.util java.util.Arrays
java.util.HashMap java.util.HashSet java.util.No
SuchElementException java.text.SimpleDateFormat java.text.DecimalFormat
java.text.Collator --package java.util.regex --package java.io
java.io.StringReader java.io.InputStreamRea
der java.io.FileInputStream --python jcchello --mapping java.util.Properties
'getProperty:(Ljava/lang/String;)Ljava/lang/String;' --sequence
java.util.AbstractList 'size:()I' 'ge
t:(I)Ljava/lang/Object;' --version 1.0 --files 4 --install
Very much appreciate your simplified example. I replicated it and understand a
few points that I was missing. In the above invocation, am I equivalently
asking for wrapping by specifying the --jar option for the archive that
contains the code to be wrapped? Do I still need --classpath per your provided
example?
For now, I have arrived at a solution that is working for us that uses a
supplemental function (as described in my initial question) to provide the
iteration over the query result set. So far, we haven't really found any
problem with this approach, except that the logic spans python and java.
This is an Apache Accumulo interface. The particular class containing the
nested class, analogous to App.Embedded.hello2(), is
TabletServerBatchReaderIterator:
http://svn.apache.org/viewvc/accumulo/tags/1.4.1/src/core/src/main/java/org/apache/accumulo/core/client/impl/TabletServerBatchReaderIterator.java?view=markup
Getting jcc to recognize MyEntry (listed below) is the actual problem I'm still
hoping to solve.
private static class MyEntry implements Entry<Key,Value> {
98
99 private Key key;
100 private Value value;
101
102 MyEntry(Key key, Value value) {
103 this.key = key;
104 this.value = value;
105 }
106
107 @Override
108 public Key getKey() {
109 return key;
110 }
111
112 @Override
113 public Value getValue() {
114 return value;
115 }
116
117 @Override
118 public Value setValue(Value value) {
119 throw new UnsupportedOperationException();
120 }
121
122 }
If this class is contained within a specified --jar argument in the jcc
invocation, can I then add a --rename command such that I can refer to the
"private" and "static" MyEntry class.
Thanks again for your kind consideration.
Craig
> JCC Nested Java Object Access from Python
> -----------------------------------------
>
> Key: PYLUCENE-21
> URL: https://issues.apache.org/jira/browse/PYLUCENE-21
> Project: PyLucene
> Issue Type: Question
> Environment: generic
> Reporter: Craig Rickle
> Priority: Minor
>
> Is it possible to access a nested object from python using jcc?
> package home;
> public class App
> {
> public class Embedded {
> public void hello2() {
> System.out.println("hello from App.Embedded method");
> }
> }
>
> public void hello() {
> System.out.println("hello from App method");
> }
> public static void main( String[] args )
> {
> System.out.println( "Hello World!" );
> }
> }
> Once processed by jcc,
> $ python -c "import jcchello;from jcchello import
> initVM,CLASSPATH,App;initVM(classpath=CLASSPATH);a = App();a.hello();"
> hello from App method
> is ok, but,
> $ python -c "import jcchello;from jcchello import
> initVM,CLASSPATH,App;initVM(classpath=CLASSPATH);a = App();a.hello2();"
> Traceback (most recent call last):
> File "<string>", line 1, in <module>
> AttributeError: 'App' object has no attribute 'hello2'
> does not resolve. We might say, ok, makes sense, lets try to --rename
> home.App\$Embedded=AppEmbedded, then, import an AppEmbedded object, but this
> approach has not worked either in the numerous forms that I have tried.
> For completeness, a jar listing follows:
> $ jar tf jcc-hello/target/jcc-hello-1.0-SNAPSHOT.jar
> META-INF/
> META-INF/MANIFEST.MF
> home/
> home/App$Embedded.class
> home/App.class
> META-INF/maven/
> META-INF/maven/home/
> META-INF/maven/home/jcc-hello/
> META-INF/maven/home/jcc-hello/pom.xml
> META-INF/maven/home/jcc-hello/pom.properties
> In reality, hello2() will effectively be a result set iterator written by an
> external group back to the python caller. Current thinking is to segment
> this portion of code as a new java method and apply jcc for subsequent
> integration. This would avoid the need to access the nested logic from
> python, but, would require blocking up the resulting data. Would appreciate
> any thoughts on this.
> Thanks in advance,
> Craig
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators:
https://issues.apache.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira