Cannot load Java class jline.console.ConsoleReader

JRUBY : 1.7.8

I am getting the classloader issue for jline. When I tired to debug with
pry it load the jline class successfully , but without debug mode it
just failed to load the class.

Other related information:

I am using my project.jar which have included
jruby-core-complete-1.7.8.jar and jruby-stdlib-complete-1.7.8.jar. I
checked manually the jline package included in the
jruby-stdlib-complete-1.7.8.jar, but the log says it looks from
jruby-core-complete-1.7.8.jar , not sure. Please help.

Log:

[2014-05-20 10:42:34] ERROR Object: cannot load Java class
jline.console.ConsoleReader
org/jruby/javasupport/JavaClass.java:1250:in for_name' org/jruby/javasupport/JavaUtilities.java:34:inget_proxy_class’
file:/tmp/jruby882017107996340294extract/jruby-core-complete-1.7.8.jar!/jruby/java/core_ext/object.rb:26:in
java_import' org/jruby/RubyArray.java:2413:inmap’
file:/tmp/jruby882017107996340294extract/jruby-core-complete-1.7.8.jar!/jruby/java/core_ext/object.rb:22:in
`java_import’

Thanks
-Khirod

I just tried with set the CLASSPATH for jruby-complete-1.7.8.jar
externaly, but still it is failing with same reason.

2014-05-20 13:09:07] ERROR Object: cannot load Java class
jline.console.ConsoleReader
org/jruby/javasupport/JavaClass.java:1250:in for_name' org/jruby/javasupport/JavaUtilities.java:34:inget_proxy_class’
file:/home/eip/installer/lib/jruby-complete-1.7.8.jar!/jruby/java/core_ext/object.rb:26:in
java_import' org/jruby/RubyArray.java:2413:inmap’
file:/home/eip/installer/lib/jruby-complete-1.7.8.jar!/jruby/java/core_ext/object.rb:22:in
`java_import’

-khirod

Now , I just extract the jline.jar from jruby-complete-1.7.8.jar and
export in the CLASSPATH externally and it works fine. But I want to use
the jline from jruby-complete-1.7.8.jar. Please help!

-Khirod

Hi Christian,

Thanks for your help. I tried your command it works fine in prompt. How
can I used it my code? Do I have to use always pry , can’t we load the
class without pry.Please help.

java -jar jruby-complete-1.7.8.jar -e ‘p require “readline/jline-2.11”;p
$CLASSPATH’
true

Thanks
-Khirod

just add

require ‘readline/jline-2.11’

before you want to use jline classes. let me know if that solves your
problem so I can improve things on the jruby side of things.

when I execute something like this:

$ java -jar jruby-complete-1.7.8.jar -e ‘p require"readline";p
$CLASSPATH’

things looks OK on my side. how do you execute jruby ?

does it help if you require ‘readline/jline-2.11’ explicitly - something
like

$ java -jar jruby-complete-1.7.8.jar -e ‘p
require"readline/jline-2.11";p
$CLASSPATH’

?

Hi Christian,

In the code I tried

p require “readline/jline-2.11”
p $CLASSPATH

It loaded successfully i.e.

true

[“file:/home/Khirod/myproject/lib/ojdbc6.jar”,
“file:/home/Khirod/myproject/lib/jruby-complete-1.7.8.jar”,
“file:/home/Khirod/myproject/lib/mycustom.jar”,
“jar:file:/tmp/jruby5839733601718663013extract/jruby-stdlib-complete-1.7.8.jar!/META-INF/jruby.home/lib/ruby/shared/readline/jline-2.11.jar”]

I used the java_import to load ConsoleReader i.e.

java_import ‘jline.console.ConsoleReader’ Here it is still failed to
load the class jline.console.ConsoleReader.

Thanks
-Khirod

I am sure this works for you as well:

java -jar
/usr/local/repository/org/jruby/jruby-complete/1.7.8/jruby-complete-1.7.8.jar
t.rb -e “require ‘readline’;java_import ‘jline.console.ConsoleReader’; p
ConsoleReader.new”

from your classpath above I see jruby-stdlib-complete-1.7.8.jar and
jruby-complete-1.7.8.jar - there is something TOO much. jruby-complete
is
jruby-core-complete + jruby-stdlib-complete ! so when you are using
jruby-complete please leave those other jars out of the classpath. hope
that helps you a step further :wink:

Thanks Christian,

The tricks works. Thanks for your suggestions.

-Khirod