Better Plugin Handling

This isn't a perfect solution since it will create a new console window for each resource, however it maintains compatibility and makes it easy on plugin authors

A new plugin class would be a good idea for a better alternative, then more advanced plugins could use that as the class base instead of just the.bytecode.club.bytecodeviewer.api.Plugin
This commit is contained in:
Konloch 2021-07-13 04:46:21 -07:00
parent 9f1877a81c
commit fc68fde546

View file

@ -1,8 +1,11 @@
package the.bytecode.club.bytecodeviewer.api; package the.bytecode.club.bytecodeviewer.api;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List;
import org.objectweb.asm.tree.ClassNode; import org.objectweb.asm.tree.ClassNode;
import the.bytecode.club.bytecodeviewer.BytecodeViewer; import the.bytecode.club.bytecodeviewer.BytecodeViewer;
import the.bytecode.club.bytecodeviewer.resources.ResourceContainer;
/*************************************************************************** /***************************************************************************
* Bytecode Viewer (BCV) - Java & Android Reverse Engineering Suite * * Bytecode Viewer (BCV) - Java & Android Reverse Engineering Suite *
@ -30,6 +33,10 @@ import the.bytecode.club.bytecodeviewer.BytecodeViewer;
public abstract class Plugin extends Thread public abstract class Plugin extends Thread
{ {
//as long as your code is being called from the execute function
// this will be the current container
public ResourceContainer activeContainer = null;
@Override @Override
public void run() public void run()
{ {
@ -40,7 +47,7 @@ public abstract class Plugin extends Thread
if (BytecodeViewer.promptIfNoLoadedClasses()) if (BytecodeViewer.promptIfNoLoadedClasses())
return; return;
execute(BytecodeViewer.getLoadedClasses()); executeContainer();
} catch (Exception e) { } catch (Exception e) {
BytecodeViewer.handleException(e); BytecodeViewer.handleException(e);
} finally { } finally {
@ -70,7 +77,22 @@ public abstract class Plugin extends Thread
} }
/** /**
* Whenever the plugin is started, this method is called * On plugin start each resource container is iterated through
*/
public void executeContainer()
{
BytecodeViewer.getResourceContainers().forEach(container -> {
//set the active container
activeContainer = container;
//call on the plugin code
execute(new ArrayList<>(container.resourceClasses.values()));
});
}
/**
* On plugin start each resource container is iterated through,
* then this is called with the resource container classes
* *
* @param classNodeList all of the loaded classes for easy access. * @param classNodeList all of the loaded classes for easy access.
*/ */