An extension to load Ghidra scripts written in Scala
Love ghidra but hate Java? If so, then this extension is for you!
Just load this extension, and Ghidra will see and be able to load any
scripts written in Scala. Just make sure their filename ends in.scala
and drop them into any ghidra_scripts
directory.
If you want to build the extension yourself, make sure you havegradle
installed, and then runGHIDRA_INSTALL_DIR=/path/to/ghidra gradle buildExtension
. If
all goes well, you should get a message like:
> Task :buildExtension
Created ghidra_9.2_PUBLIC_20201117_ghidra-scala-loader.zip in /home/ed/Documents/ghidra-scala-loader/dist
BUILD SUCCESSFUL in 11s
4 actionable tasks: 1 executed, 3 up-to-date
In this case, the filedist/ghidra_9.2_PUBLIC_20201117_ghidra-scala-loader.zip
is your
newly built extension.
Start Ghidra, and in the initial window (i.e., not the Code
Browser), open the File
menu, and select Install Extensions
.
Click the small plus icon in the top right of the window, and select
the extension zip file that you built above. This should add an
extension into the list, ScalaScriptProvider
. Make sure the
checkbox is ticked, and click OK to close the window. Ghidra will
tell you that you need to restart to load the extension. Do so.
To make sure the extension loaded correctly, open the Code Browser,
and under the Window
menu, select Script Manager
. If all is well,
you should see a HelloWorld.scala
script. Right click it, and
select Run
. You should see the hello world message print out to the
Console.
This extension should work with JDK 17 or 21, but the prebuilt Github extensions
will only work with the JDK version required by the Ghidra version they are
built for. If you want to use a different JDK version, you will need to build
the extension yourself.