项目作者: edmcman

项目描述 :
An extension to load Ghidra scripts written in Scala
高级语言: Java
项目地址: git://github.com/edmcman/ghidra-scala-loader.git
创建时间: 2019-03-21T14:21:13Z
项目社区:https://github.com/edmcman/ghidra-scala-loader

开源协议:

下载


Build Status
Dynamic YAML Badge

Introduction

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.

Compilation

If you want to build the extension yourself, make sure you have
gradle installed, and then run
GHIDRA_INSTALL_DIR=/path/to/ghidra gradle buildExtension. If
all goes well, you should get a message like:

  1. > Task :buildExtension
  2. Created ghidra_9.2_PUBLIC_20201117_ghidra-scala-loader.zip in /home/ed/Documents/ghidra-scala-loader/dist
  3. BUILD SUCCESSFUL in 11s
  4. 4 actionable tasks: 1 executed, 3 up-to-date

In this case, the file
dist/ghidra_9.2_PUBLIC_20201117_ghidra-scala-loader.zip is your
newly built extension.

Installation

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.

Requirements

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.

Supported Versions

Dynamic YAML Badge