From 32d2e9756bb757b43cf6b78614ab7e444c7255c5 Mon Sep 17 00:00:00 2001 From: Nick Battle Date: Thu, 30 Nov 2023 11:34:29 +0000 Subject: [PATCH] Allow PluginRegistry to do usage and processArgs --- .../java/com/fujitsu/vdmj/plugins/Lifecycle.java | 12 ++---------- .../com/fujitsu/vdmj/plugins/PluginRegistry.java | 16 ++++++++++++++++ 2 files changed, 18 insertions(+), 10 deletions(-) diff --git a/vdmj/src/main/java/com/fujitsu/vdmj/plugins/Lifecycle.java b/vdmj/src/main/java/com/fujitsu/vdmj/plugins/Lifecycle.java index 253364787..9090fd098 100644 --- a/vdmj/src/main/java/com/fujitsu/vdmj/plugins/Lifecycle.java +++ b/vdmj/src/main/java/com/fujitsu/vdmj/plugins/Lifecycle.java @@ -146,8 +146,6 @@ else if (argv.contains("-vdmrt")) private void usage() { - List plugins = PluginRegistry.getInstance().getPlugins(); - println("Usage: VDMJ [-vdmsl | -vdmpp | -vdmrt] [] []"); println("-vdmsl: parse files as VDM-SL (default)"); println("-vdmpp: parse files as VDM++"); @@ -161,10 +159,7 @@ private void usage() println("-q: suppress information messages"); println("-verbose: display detailed startup information"); - for (AnalysisPlugin plugin: plugins) - { - plugin.usage(); - } + PluginRegistry.getInstance().usage(); System.exit(0); } @@ -268,10 +263,7 @@ protected void processArgs() } } - for (AnalysisPlugin plugin: PluginRegistry.getInstance().getPlugins()) - { - plugin.processArgs(argv); // In priority order - } + PluginRegistry.getInstance().processArgs(argv); // In priority order } protected void loadPlugins() diff --git a/vdmj/src/main/java/com/fujitsu/vdmj/plugins/PluginRegistry.java b/vdmj/src/main/java/com/fujitsu/vdmj/plugins/PluginRegistry.java index 77aebec57..9eeecaefd 100644 --- a/vdmj/src/main/java/com/fujitsu/vdmj/plugins/PluginRegistry.java +++ b/vdmj/src/main/java/com/fujitsu/vdmj/plugins/PluginRegistry.java @@ -97,6 +97,22 @@ public List getPlugins() return sorted; } + public void usage() + { + for (AnalysisPlugin plugin: getPlugins()) + { + plugin.usage(); + } + } + + public void processArgs(List argv) + { + for (AnalysisPlugin plugin: getPlugins()) + { + plugin.processArgs(argv); // In priority order + } + } + public AnalysisCommand getCommand(String line) { String[] argv = line.split("\\s+");