Saturday Jan 09, 2010

Looking for debug-commons maintainer and/or developer(s)

If you would like to work on JRuby debugger and/or Ruby debugger backends for Ruby IDEs let me know. More in the post on the new blog.

Leaving Sun, future blog, musing...

So it came. I'm leaving Sun at the end of January 2010 which means that this blog will be dead even more then it was :). I've just founded (new and empty now) blog at (a bit shorter then the "real" address where I would like to post now and then about various topics which are interesting for me and hopefully might be interesting and useful for others as well. I'm not sure yet about what exactly but I plan to spend my spare time and thus possibly blog about topics related to:

  • more about Vimming. I'm using the editor for, let's say +10 years and I think (like a lot of others) that I have some nice tweaks that would be worth to share publicly. I want to improve it for some languages I'm using/learning which is these days mainly Haskell. There is already very nice Haskell mode (unfortunately without public repository) and I have another bunch of tweaks like IDE-like "Output Window" with "hyper-linked" compiler errors/warnings, go-to-source for GHC core libs (yup, just tag them actually), etc. There is also emerging Scion project which might learn one a lot from both, Haskell and Vim, point of views, still useful for others which is also plus :). So I want to explore and might be try to contribute to those projects.
    There is lot of language agnostic settings which regards also other languages, so it will not be about Haskell vs. Vim only.

  • starting Haskell project for Design Concepts in Programming Languages (DCPL) textbook (nice Christmas present I got) which would be kind of what tapl-haskell is for Types and Programming Languages book. This is definitely long time project since this tome does not seems to be a piece of cake for me - not only because of its weight :). So far I've just started the reading and implemented first (not so nice) version of PostFix stack language interpreter and then break to skim through the mathematical Metalanguage appendix. So long way...
    Unfortunately there does not seem to be solutions accessible for the DCPL, just a bit of source code (see this LtU thread) which means that some of my solutions to the book's answers will possibly be just wrong. But the best way to check one's answer is to share them with the rest of the world.

  • math - something where my knowledge are just weak (if I say it nicely for myself). Thus I want to finish bunch of books I bought or borrowed from our great library about discrete math and others CS math-related topics and revive my semi-dead calculus knowledge. So I really do not want to advice others wrt. math, but I might share some nice resources which are helpful for the kind of similar mathematical academic disasters like me ;) to better understand this nice art and explore it wrt., or confront it to, the PL topics from the "student" point to view.
    BTW if you do not like math because it seems too hard and strange and/or you do not have "official" university background (like me), try to read The Language of Mathematics: Making the Invisible Visible by Keith Devlin. Very inspirational easy-reading starter which was a kick for me two or so years ago. Then imagine where you might be in few years if you get a bit of Math Every Day (inspirational posts by Steve Yegge). That should be enough to make you fall in love with math and to start to bite a bit now and then, juts like a hobby instead of e.g. evening sudoku session :)

    For self-learners who did not hit the site yet, one of the links above is Khan Academy. It is not good just for math, but great resource for other domains as well. E.g. start to watch bunch of chemistry lessons and you will see that you will somehow want to start to learn more about chemistry :). The presentations are really well done. Big kudos to the man behind, Salman Khan. Mostly all (or all?) lessons done by one men.

  • And other random, likely programming languages related topics...

So this is approximately what the new blog might be about in the beginning. It might be affected by whether I really take a longer "vacation" and will be a full-time student (sounds good :) ) which is what I want and plan to realize or whether I will start to work soon which I do not want that much ;). But there might be some great close-future opportunities which will be hard to decline when they are almost hobbies.

Also since I do not like to blog about topics which have been blogged about several time it will be rather occasional blogging, as in the Ruby-time era I think. So just to be clear for the case somebody really wants to follow :)

As usually leaving a job is both, bad and good. Bad side is leaving bunch of most talented people I've ever met, but on the other side I'm looking forward to new interesting opportunities and enjoying the free time by reading all the books mentioned plus other CS bibles I've never finished due to the lack of time. (I know, only those three book might take years). And sure a lot of "normal" free time activities like biking, swimming, skiing, hiking, traveling will take more of their time. So does not sound that bad at all :)

You might reach me through my Gmail martin.krauskopf account or contact me through LinkedIn profile which I've just set up (after having it just empty for some time already).

Tuesday Nov 10, 2009

Church booleans vs. JavaFX (vs. Haskell)

Recently I've started to read Types and Programming Languages with which I normally use Haskell([1]) for book's interpreters implementation and for helping to solve some exercises. But since I've joined the NetBeans JavaFX support development I'm also learning JavaFX language. And in order to learn the JavaFX language a bit more, I chose ¨perfect¨ ;) usecase for it - Church encoding of boolean values ( Church booleans). Below is the result. For comparison and might be for better understanding I'm also attaching Haskell (which naturally fits much better for the exercise) solution which is kind of easier to read, since it's just almost direct translation of Lambda Calculus notation.

Small complains against JavaFX:

  • compiler type-inference failed in result sequence thus as operator has to be utilized.
  • I need to provide function signature for a bunch of parameters as well. Those could be also inferred. (I've provided type signatures for Haskell just for better readability. Note that they might be all deleted and GHC will infer all types correctly)
  • other problem causing verbosity is due to the impossibility to specify type alias. As might be done in Haskell with: type ChurchBool = forall a . a -> (a -> a) . Probably could be handy in JavaFX here and there as well.

To be fair JavaFX is aimed for quite different domain then Haskell for which this solution fits really well. And might be I misunderstood or do not know some JavaFX syntax/features which would make the code neater.

And sure, this is artificial and probably not that useful case :) But one usually understand the language's dark corners by non-standard language utilization. Try to rewrite some monads into JavaFX. So far I've failed to come with at least a bit sane solution for Maybe monad. Anybody? :)

Haskell sources:

 1 {-# LANGUAGE RankNTypes #-}
 3 import Prelude hiding (and, or, not)
 5 type ChurchBool = forall a . a -> (a -> a)
 7 -- tru = λt. λf. t
 8 tru :: ChurchBool
 9 tru = \\t -> \\f -> t
11 -- fls = λt. λf. f
12 fls :: ChurchBool
13 fls = \\t -> \\f -> f
15 -- test = λl. λm. λn. l m n
16 test :: ChurchBool -> a -> a -> a
17 test = \\l -> \\m -> \\n -> l m n
19 -- and = λb. λc. b c fls
20 and :: ChurchBool -> ChurchBool -> ChurchBool
21 and = \\b -> \\c -> b c fls
23 -- or = λb. λc. b tru c
24 or :: ChurchBool -> ChurchBool -> ChurchBool
25 or = \\b -> \\c -> b tru c
27 -- not = λb. b fls tru
28 not :: ChurchBool -> ChurchBool
29 not = \\b -> b fls tru
31 -- just utility tester
32 :: ChurchBool -> String
33 t b = test b "tru" "fls"
35 main =
36   mapM_ putStrLn
37     [ "-- tru test"
38     , t tru
40     , "-- fls test"
41     , t fls
43     , "-- and test"
44     , t $ and tru tru
45     , t $ and tru fls
46     , t $ and fls tru
47     , t $ and fls fls
49     , "-- or test"
50     , t $ or tru tru
51     , t $ or tru fls
52     , t $ or fls tru
53     , t $ or fls fls
55     , "-- not test"
56     , t $ not tru
57     , t $ not fls
58     ]

JavaFX sources:

 1 package javafxtester;
 3 def tru = function(t) { function(f) { t } }
 4 def fls = function(t) { function(f) { f } }
 6 def test = function(l:function(:Object):(function(:Object):Object)) {
 7     function(m) {
 8         function (n) {
 9             l(m)(n)
10         }
11     }
12 }
14 def and_ = function(b:function(:Object):(function(:Object):Object)) {
15     function(c) {
16         b(c)(fls)
17     }
18 }
20 def or_ = function(b:function(:Object):(function(:Object):Object)) {
21     function(c) {
22         b(tru)(c)
23     }
24 }
26 def not_ = function(b:function(:Object):(function(:Object):Object)) {
27     b(fls)(tru)
28 }
30 // just utility tester
31 function t(b:function(:Object):(function(:Object):Object)) {
32     test(b)("tru")("fls")
33 }
35 var results =
36     [ "-- tru test"
37     , t(tru)
39     , "-- fls test"
40     , t(fls)
43     , "-- and test"
44     , t(and_(tru)(tru) as function(:Object):(function(:Object):Object))
45     , t(and_(tru)(fls) as function(:Object):(function(:Object):Object))
46     , t(and_(fls)(tru) as function(:Object):(function(:Object):Object))
47     , t(and_(fls)(fls) as function(:Object):(function(:Object):Object))
49     , "-- or test"
50     , t(or_(tru)(tru) as function(:Object):(function(:Object):Object))
51     , t(or_(tru)(fls) as function(:Object):(function(:Object):Object))
52     , t(or_(fls)(tru) as function(:Object):(function(:Object):Object))
53     , t(or_(fls)(fls) as function(:Object):(function(:Object):Object))
55     , "-- not test"
56     , t(not_(tru) as (function(:Object):(function(:Object):Object)))
57     , t(not_(fls) as (function(:Object):(function(:Object):Object)))
58     ];
60 for (r in results) println(r);
[1] yup, I know that the TAPL's language of choice is OCaml but I'm just reading through Real World Haskell. Nothing personal against OCaml :) Similar folks might be interested in tapl-haskell project.

Sunday Nov 23, 2008

Open simply whatever non-NetBeans Ruby (on Rails) project in NetBeans

Subtitle: Poor man's, but effective and simple solution

This is a tip (or trick) for how to quickly open any project (Rails or non-Rails one) without any NetBeans metadata in NetBeans. E.g. from RubyForge, Kenai, GitHub, ... or just your local one. In short, all you need is to run nb_ruby_project command (which is Ruby few-liner (excluding NetBeans metadata)) and press C-S-1 in NetBeans.

nb_ruby_project is downloadable/viewable on pastie or here.

You need just change the two lines in the script to point to your netbeans executable and optionally to your userdir if you are using non-default one (e.g. --userdir option during start-up).

NB_BIN = '/path/to/netbeans/bin/netbeans'
# NB_USER_DIR = '/path/to/optional/userdir'

You might also start-up NetBeans before using the script (but not necessary)

$ nb_ruby_project 
Usage: nb_ruby_project <ruby_project_dir> [--rails]

For example see the following two-step (checking out and opening in NetBeans) terminal session for how to open RubyGems project from RubyForge:

$ svn co svn:// rubygems
$ nb_ruby_project rubygems

Project: rubygems (non-Rails)

Will create following files (NetBeans metadata) in:

Press "y<Enter>" to agree: y
Mentioned NetBeans metadata created

Opening 'Rakefile' in NetBeans...

Now the project's Rakefile should be opened in the running NetBeans session (or new NetBeans instance is started). Just press there C-S-1 (Menu | Navigate | Select in Projects) and press <Enter> to confirm the dialog as shown on the image below.

Open RubyGems in NetBeans

After the project is opened you might want to set different Ruby platform, add more sources and/or roots, rename the project, etc.

This is just workaround for the issue 126410 which should enable to do this from NetBeans directly. But I'm using the script very often for RubyForge-alike sites in the meantime, so sharing.... It might be enhanced with bunch of small features, like asking for source roots, being Ruby-independent, etc. But it's just a temporary workaround... hopefully not for too long.

Note that you can open all the gems you have installed on your machine, see your $GEM_HOME/gems directory. You might also use the script from CLI to quickly open projects already containing NetBeans metadata (metadata creation will be just detected and skipped) during browsing your harddisk.

Tuesday Nov 11, 2008

Remote Debugging: explore Ruby code easily

In the NetBeans 7.0 (dev) you may attach debugger to any process which have been started from the command line, with all the goodies of UI debugger frontend. This means that if you just found some strange behaviour or bug in some CLI tool or you are just curious how e.g. gem list, rake -T, etc. commands work, just run then in debug mode from a terminal and attach to them from the frontend.
There is no need to setup a NetBeans project, even not to open the file or doing whatever in NetBeans, just invoking Menu | Debug | Attach action there.

Let's say we are curious how does gem list --local works.

  • you need to have have ruby-debug-ide in version 0.4.1 (just released) or later installed
  • Run rdebug-ide -p 7000 --stop -- `which gem` list --local. On Windows just replace `which gem` with the c:\\full\\path\\to\\the\\gem command
    (the --stop switch ensures that the debugger stops on the first line. This might not be always what you want if you've set the breakpoints in advance in the NetBeans frontend (e.g. after the first run with the --stop switch). Then just omit the switch and debugger will run until the first breakpoint is hit)
  • In NetBeans invoke Menu | Debug | Attach choose Ruby Debugger in the Debugger combobox if there is more choices (you have also e.g. Java support installed)

That's all. Debugger will stop on the first line of the debuggee. After few steps you are inside RubyGems guts peeking around for how does it actually work.

RubyGems debugging

This is the first step letting you to attach NetBeans debugger to the application run from CLI and/or on another machine. Next step is to provide functionality similar to ruby-debug that you will be able to put a call like:

  if something_peculiar_has_happened
    require 'ruby-debug-ide'
    debugger(7000) # 7000 being a port

into your application and attach to it from the frontend.

Altough this is kind of "remote" debugging and you may attach to the process which was run on another machine, there are not yet sources association implemented in NetBeans. So you would have to have sources located on the same paths on the local machine as the one on the debuggee's machine. But for the case similar to the above which are probably the most frequent one this might be very usefull.

Worth to add that the support were added quite recently. I've also made the code base little bit more "aggressive" which should help to stabilize the debugger a bit more among the layers (from base backend up to the frontend) and prevent kind of random exception. So if you found any problems the feedback is more then welcomed. Either let me know here or through the mailing list or Issuezilla. Thanks

Tuesday Oct 21, 2008

Cross-language debugging: from Ruby to Java and back

Until we bring the full support for two ways debugging - from Ruby to Java and vice versa; the following "trick" might be used to debug Ruby and Java at once in the NetBeans 6.5 (you might get 6.5 build here). It might be used to debug standard JRuby applications/scripts, JRuby's Java extension or JRuby's internals itself. I'm using it for some time during development of JRuby Fast Debugger extension.

The trick is to start actually two debugging sessions, one for Ruby part and second for Java part (JVM under which JRuby runtime runs). Sessions then automatically activate themselves when the breakpoint for their language is hit.


Except the Ruby IDE, we need to have Java support installed if it is not already the case. This can be find out by looking e.g. into the New Project Wizard. If the Java category is there, we have all we need. If not see the How do I install the Java support into the Ruby NetBeans IDE? FAQ.

So how to utilize it

  1. Open a (J)Ruby project utilizing some Java classes
  2. Go to its properties -> Run category and set JVM Arguments to -Xdebug -Xrunjdwp:transport=dt_socket,address=7000,server=y,suspend=y like on the screenshot (for Rails project the field has to be edited through properties file manually).

    JVM Arguments
  3. Then set the breakpoints in the Ruby code and Java code
  4. Start to debug the (J)Ruby project: Menu | Run | Debug Project
  5. Connect to the JRuby's JVM session: Menu | Debug | Attach Debugger, enter the port 7000, confirm the dialog. (Note that this need to be done within 15 seconds after the Ruby debugger was triggered (previous step). If that's not enough for you, you might increase the Ruby debugger timeout)

    Attach Debugger

That's it. As can be seen on the following screenshot, after I do a step in the Ruby code, Java debugging session take over the control and I'm debugging the Java code called from Ruby code with the full power of NetBeans Java debugger. Once I'm done with Java side I'll just press F5 (Continue) and Ruby debugging session takes back the control and I can continue with the debugging of Ruby part.
Note that if you have JRuby sources you might just set the breakpoint somewhere in the JRuby interpreter's guts and take a look what going around in there.


Clearly not fully-fledged cross-language debugging. Since sessions live their life independently, actions like Step Into, Step Over and similar do not work in the cross-language context. We have to simulate Step Into and similar actions by putting breakpoints on appropriate places. Stacktrace is not shared, so we get two, one for each language, instead of one with nicely mixed frames from both languages. But still, I find it pretty handy during JRuby Fast Debugger development.
If you do not want to repeatedly delete and add the long string from the step 2, you might create a configuration as might be seen in the properties screenshot (JRuby Debug in Configuration combobox).

To watch the progress on fully-fledge cross-language debugging, you might CC yourself to this RFE in the Issuezilla.

Monday Jul 07, 2008

Rake Task Runner

Executing Rake tasks in the NetBeans 6.1 is little bit cumbersome and inconvenient. To run a single Rake task you have to invoke project's context menu, navigate to the desired task, usually with the sluggish help of mouse. Clearly, the same for debugging a Rake task. If you have made a change to the Rakefile you have to manually trigger the Refresh List action, again the same long way through the context menu.

Old, 6.1 way:

Working on the debug-commons project I often ended up in the command line which was kind of bad feeling when working on NetBeans Ruby IDE ;)

This has changed in NetBeans 6.5 with new Rake Task Runner and few related changes. Now running/debugging a Rake task is quicker then using the command line.

  • CLI: rake test<Enter>
  • NetBeans: <Alt+Shift-R>te<Enter>

Few key strokes saved in NetBeans ;) Moreover you will get another bunch of features in Rake Task Runner.

New 6.5 Rake Runner:

It might be easily invoked through Alt+Shift-R (or through the project context menu if you really prefer the mouse way). Then just type few (not necessarily first) letters of the task to be run and press <Enter> like you are used to from Go To File or Go To Type dialogs.

To run the same task again just press Alt+Shift-R, <Enter>. The lastly run task is remembered. Or you might use Rerun button in the Output Window's tab.

Other features, new in 6.5:

  • possibility to pass parameters to Rake tasks (e.g. to db:migrate or test tasks)
  • possibility to see undocumented task (rake tool by default does not show tasks without description)
  • automatic detection of changes in the Rakefile
  • full description of each Rake task
  • merge of Debug and Run task context menu (just check the checkbox to debug the task)
  • better diagnostic when something goes wrong

Another related change is pre-generated useful Rakefile for newly created Ruby project. In 6.1, when you created a new project, you got an empty Rakefile. In 6.5 you will get Rakefile template containing classic tasks like clean, gem, rdoc, test, etc. (thank to Dudley Flanders for suggestions).

Also few menu items among the IDE are tied up with the pre-generated Rakefile, like Build and Clean actions in project's context menu which did nothing in 6.1.

Thanks to Erno, his Test Runner cooperates with the Rake Runner as well. So when you trigger tasks like test or spec, Test Runner will jump in and shows test result in a nice UI manner.

There are still a lot of place for improvements. If you have more ideas which you would like to see in NetBeans let us know. We have only a few days until Feature Freeze, so sooner is better. To try the new features you need to get 6.5 build as described in the wiki. As with all dev builds there might be some not-yet-discovered bugs, so better to keep one dev build, which works for you, back. I'm using 6.5 for my daily Ruby and Java job without too much issues. So encouraging you to try it as well ;). Moreover with 6.5 dev builds we might come with a fix to a bug you find in hours when at least somehow possible. That's much harder with already released 6.1.

Friday Jun 13, 2008

JRuby Fast Debugger 0.10.1

Friday the 13th, the good time for a new release :), here it is:


  • Main feature or benefit is that all the new features of MRI's CLI fast debugger might now be utilized. See CHANGES and Changelog for ruby-debug 0.10.1 release and check Debugging with ruby-debug manual. Rocky Bernstein pushes the CLI interface to be compatible with, or similar to, the one used for gdb. So be sure to check the CHANGES or type 'help' command into debugger console to check the new commands or the ones whose behaviour have changed.
  • No -J-Djruby.reflection=true -J-Djruby.compile.mode=OFF monster is needed any more. JRuby 1.1.2 (see JIRA 2474 for details) comes with special flag for debugging. Now all is needed is to pass --debug parameter to JRuby. So to debug your application, you just need to run:
      jruby --debug -S rdebug <your-script>
  • ruby-debug-base since version 0.10.1 depends on other native gem - linecache. With jruby-debug-base this is not needed since we are workarounding this by dummy linecache fake directly in jruby-debug-base. This means that we are not as clever as C ruby-debug-base - particularly in JRuby debugger you might put breakpoint on lines with no executable code where C implementation would cleverly reject it. In future there will be hopefully decent implementation of linecache. Any volunteer? :)
  • we are now passing almost whole, little bit tweaked, test suite of MRI ruby-debug 0.1.10. Few patches were contributed to ruby-debug-base implementation independence (whether it is MRI, JRuby or Rubinius one). Thanks ruby-debug team for the great test suite. This helps stability and compatibility of all implementations.
  • following up from the above point several bugs were fixed.
  • see ChangeLog for details.

Good to know

Since there were some API changes in JRuby 1.1.2 the jruby-debug-base 0.10.1 release does not work with JRuby 1.1.1 and older, only with JRuby 1.1.2+.


For installation see debug-commons website or Using the JRuby Debugger on JRubyWiki.

Enjoy and any feedback is welcomed as always.

Wednesday May 07, 2008

Scripting NetBeans in Ruby

Few times we were asked whether is is possible to write NetBeans Ruby IDE extensions in Ruby. We usually replied not yet. But having:

  • NetBeans running on the JVM
  • JRuby on the same VM
  • JSR 223 which is part of JDK 6

there are no reasons why it should not be possible now.

So I've started to peek around what would be needed to provide convenient extension with which the Rubyists would be able to start to tweak NetBeans IDE in Ruby language only. I did not start exactly with such support, but instead started with kind of NetBeans Ruby IDE scripting support. I've recalled Jesse's idea for IDE scripted by JavaScript and applied similar to Ruby.

Working with NetBeans Ruby's dev builds and very often starting with clear userdir and still reopening my projects, I now have the following script instead which I simply run from CLI after fresh NetBeans starts up (just work from IRB as well):

  1 require 'nb_ext'
  2 netbeans = NBExt.find_first
  3 netbeans.attach
  4 netbeans.open_projects(
  5   '/space/java/netbeans-hg/main/ruby.debugger',
  6   '/space/java/netbeans-hg/main/ruby.platform',
  7   '/space/java/netbeans-hg/main/ruby.project'
  8 )

How does it work?

Below are some details of implementation with inlined snippets of code for convenience. Full code might be downloaded here, Java agent here.

(2) The script finds running NetBeans instance. The find_first methods goes through the currently running JVM instances and greps for the NetBeans and returns the first one (or nil). Thus if you are running more NetBeans instances use find_by_userdir or find_all instead.

  1 vm_desc = VirtualMachine.list.detect do |desc|
  2   desc.display_name =~ /org.netbeans.Main/i
  3 end

(3) attach to it via Attach API

  1 VirtualMachine.attach(@vm_desc)t

(4) and opens given project(s) in the running NetBeans IDE. open_projects method just compose projects to be opened with the code utilizing NetBeans APIs (open_projects_code.rb) and sends it to the agent, running inside NetBeans process VM, for evaluation.

   1 def open_projects(\*projects)
   2   code = "projects = ['#{projects.join("','")}']\\n"
   3   code_file = File.join('code', 'open_projects_code.rb')
   4   code <<
   5   eval_code(code)
   6 end
   8 def eval_code(code)
   9   output ='output')
  10   @vm.load_agent(@agent_jar, "#{output.path}#{File::PATH_SEPARATOR}#{code}")
  12 end

Template for opening projects is simple:

   1 include Java
   3 import ''
   4 import 'org.netbeans.api.project.FileOwnerQuery'
   5 import 'org.netbeans.api.project.ui.OpenProjects'
   7 raise("projects must be defined") unless defined?(projects)
   9 to_open = do |prj|
  10   uri ="file://#{prj}")
  11   FileOwnerQuery.get_owner(uri)
  12 end.compact
  14 to_open_p = to_open.to_java('org.netbeans.api.project.Project')
  15 OpenProjects.getDefault().open(to_open_p, false)

Note that projects variable is defined in the open_projects method code composition. Likely templating mechanism would fit here.

Everything written in the Ruby language, just agent class is written in Java (with future JRuby compiler even this piece could be written in Ruby).

Just a playground so far…

This is really just an example how it might be done. Developing such extensions, or writing such scripts, is still little awkward and not that easy to test and one needs to know NetBeans APIs, but that's likely OK when wanting to write NetBeans extensions/scripts.
In the future we could bridge some basic NetBeans APIs to Ruby, like the artificial open_projects method above, to make it easy to write such scripts which adds e.g. new menu items. Also it should not be hard to write some support into NetBeans where you would manage your scripts and which will be automatically loaded when NetBeans starts up. Ideally there would be also some support for testing such script -> write in IDE, run/test it in IDE. Not that simple, but something like this.

It depends whether there is really such a request from NetBeans Ruby users and whether the effort spends on the support does worth it, whether the NetBeans users would like to script or extends NetBeans in Ruby and what would be such use-cases.

If you have any ideas how such support should look like or how does it look in other IDEs, Editors supporting Ruby extensions, let me know.

Can I try it?

Yes, you can. But it might not be that easy at the moment since we are facing issue with bundled tweaked JRuby. So firstly you might try to download and install this NetBeans module (4384kB!, contains jruby.jar) which should enable JRuby scripting in Netbeans. I've spent some time with this but still does not work. On the other hand my colleague Erno, does not have problems I'm encountering. So your mileage may vary.
If it throws strange JRuby internal exceptions, use second brute-force method, and just copy-paste jruby.jar from your JRuby distribution (lib/jruby.jar) and jruby-engine jar to your $JAVA_HOME/jre/lib/ext directory. Then start the NetBeans IDE and above should work. You will get some exceptions from our NetBeans Ruby lexer/parser if you used brute-force method, but for playing should be enough until we solve the issue appropriately.


Martin Krauskopf


« December 2016