Next example - example14_my_optimizer.zubr. In the declaration section we have the following code:
// This is an example zubr specification.
package optimizer;
%option class MyOptimizer // here we modify the target class name, it is optional
// We can import Java packages here.
import javax.swing.JFrame;
import java.awt.Dimension;
The instruction %option class MyOptimizer is not a Java code, it is a zubr option. It tells zubr we want to change the default target class name. Nothing complicated. We must take it into account and modify the class OptimizerThread accordingly:
protected static class OptimizerThread extends Thread {
private MyOptimizer optimizer;
public void run() {
optimizer = new MyOptimizer();
optimizer.loop(1);
}
}
Now it creates MyOptimizer rather than Optimizer. Also note that we added in the declaration section "package optimizer;" - this means that we have to place the result Java code in a package "optimizer" (you have to create the package). As usual we can execute this example with zubr:
zubr example14_my_optimizer.zubr > MyOptimizer.zubr
The result code should be compiled with a java compiler and executed. But it still only instantiates an optimizer and runs the loop without any means to communicate with the outer world. How to make the communication? Be patient, this will be covered in next examples.
For the Windows users - I have created an installer: http://www.pawelbiernacki.net/perkun.msi.
Download zubr from https://sourceforge.net/projects/perkun/.
No comments:
Post a Comment