-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME
62 lines (43 loc) · 2.3 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
Prototype Plugin
The goal is to develop a framework for external developers to develop modules
that augment the functionality of BEAST. The developer would be able to produce
a small jar for users to download. Then referencing the plugin's objects in a
BEAST XML input would be sufficient to use the plugin -- BEAST itself should not
need to be recompiled.
== Creating a stub ==
If you have python installed, then you can run generate_stub.py for example:
$ python generate_stub.py -x elname -p beastplugin.test -c testPlugin
To generate the stub for beastplugin.test.testPlugin that provides a parser for
the <elname /> xml elements in BEAST's input.
== Configuring your build env ==
To use ant, you will need to create a beast_sdk.properties file that defines
the beast.root for your machine. You can copy beast_sdk.properties.in to
beast_sdk.properties and then edit that file. The value for boost.root will
the path on your filesystem where you checked out:
http://beast-mcmc.googlecode.com/svn/trunk
(Shell commands in this document will use BEAST_ROOT to refer to this path, but
you do not need to modify your shell's environment to build a plugin -- this is
just a convention for these instructions).
== Building beast.jar ==
To build a plugin the beast.jar must be up-to-date.
$ cd ${BEAST_ROOT}
$ ant -f build_BEAST_MCMC.xml build_jar_all_BEAST_NoJUnitTest
You should then have the file:
${BEAST_ROOT}/build/dist/beast.jar
== Building the plugin ==
$ ant build
== Installing the plugin ==
This target copies the jar for the plugin into $BEAST_ROOT/plugins
$ ant install
== Testing the installed plugin ==
This target checks that plugin integrates with BEAST.
Note: that for Beast to find the plugin when you invoke it from an external
directory. This target uses a -Dbeast.plugins.dir=${beast.root}/plugins argument
to java so that the plugins directory will be found
$ ant test-install
This will create a use the XML instance document in your plugin's example
directory to test that the plug in is being used. Note that the simple Plugin
Template used to generate your stub has a parser that creates an HKY model as
your plugin's object. As you write your Plugin, you'll modify the code
(obviously), but you will also need to update the example xml document if you
want the test-install target to work.