( JRuby Forumでクロスポストされましたが、まだ回答が得られなかったため、ここに再度投稿しました)。
プラットフォーム: jruby 9.0.4.0 (2.2.2) 2015-11-12 b9fb7aa Java HotSpot(TM) 64 ビット サーバー VM 24.79-b02 on 1.7.0_79-b15 +jit [Windows 7-amd64]
RedBridge Core を介して JRuby コードを呼び出す Java のメイン プログラム。Java クラスは Jar-File にあります。
Ruby コードがファイル システム内で検索されるのではなく、Jar ファイル内からも実行されると主張しない限り、このセットアップは機能します。Jar ファイルからコードを実行すると、JRuby の stdout が消えてしまったようです。
まず、これがWORKINGケースです:
// My main program (Jmain.java):
import vp.VP;
public class Jmain {
public static void main(String[] args){
System.out.println("Jmain started");
VP vp = new vp.VP();
System.out.println("vp instance created");
vp.run();
System.out.println("Jmain terminating");
}
}
// My VP class (VP.java):
package vp;
import org.jruby.runtime.builtin.IRubyObject;
import org.jruby.RubyObject;
import org.jruby.embed.ScriptingContainer;
import org.jruby.embed.LocalContextScope;
import java.util.*;
public class VP {
private ScriptingContainer container;
public VP() {
container = new ScriptingContainer(LocalContextScope.SINGLETHREAD);
}
public void run() {
RubyObject asahi =
(RubyObject)container.runScriptlet(
org.jruby.embed.PathType.RELATIVE,"rbsrc/bridge.rb");
System.out.println("scriptlet executed");
}
}
# My Ruby program rbsrc/bridge.rb
puts "Entering bridge" # Just to see what's going on
File.write("out.txt","This file was created by bridge.rb\n")
# ... rest of the code not shown
:: I put everything into a jar file, including the Ruby files
:: (although I don't need them there yet).
jar cvfm jars\vp.jar .... rbsrc
:: The program is executed like this:
java -cp c:\jruby-9.0.4.0\lib\jruby.jar;jars\vp.jar Jmain
すべての println ステートメントの結果が表示され、ファイル out.txt が作成されます。
次に、NON-WORKING ケースの場合:
全体の設定で、1 行だけ変更します。bridge.rb の呼び出しは次のようになります。
RubyObject asahi =
(RubyObject)container.runScriptlet(
org.jruby.embed.PathType.CLASSPATH,"bridge.rb");
つまり、RELATIVE を CLASSPATH に置き換え、「rbsrc/」を削除します。これを実行すると、エラー メッセージは表示されず、すべての println ステートメントの出力が得られますが、「puts」ステートメントの出力は表示されず、ファイル out.txt も作成されません。
bridge.rb は正しく読み込まれているように見えますが (bridge.rb を別の名前に変更すると例外が発生します)、実行されていないようです。
どうして?
更新: 問題の説明が間違っていました! stdout に問題はありませんが、JRuby コードbridge.rb
が実行されていないようです。runScriptlet
を返しnull
、Rubyプログラム内でファイルを作成すると、その後ファイルがありません。
私は何を間違っていますか?すべての JRuby ファイルを 1 つのディレクトリに格納しています。それらをJarファイルに入れました。を使用して実行しjar -cp JARFILE MAINCLASS
ます。他に何が欠けていますか?
ところで、サンプル アプリケーション全体はここにあります。込みがありreadme.txt
ます。