我把这些放在这里,所以那些想用 ZenScript 使用它们的人可以找到。

Zen 类本质上就是一个 java 类,但你也可以用 ZenScript 来定义。
如果你觉得 “这一点像都不脚本语言” 那么你说对了。


These are keywords that can be found in the class’ body and they will initiate a certain action, like adding a member to the class.

Name Descrition
zenClass Starts a new class, needs to be followed by the name.
var/val Creates an instance variable, final of the val keyword was used.
static Creates a class (static) variable. They can’t be final.
zenConstructor Creates a constructor for the class.
function Creates an instance method. There’s no way of creating static methods, as you can do that outside the class as well.
this Reference to the object we are currently in. Only useable in methods and constructors. Used if a parameter hides a field, for example.


A commented example:

<br />//Creates a class named 'name', you can also access it using scripts.scriptPath.name

zenClass name {

    //Each variable needs a type set. 
    //Variables don't need to be initialized, but if you do, initialization is as in Java.

    //Statics are initialized in &lt;clinit&gt;, i.e. when the class is first defined.
    static myStatic as string = "value";
    static otherStatic as string = "value";

    //If an instance varaible has an initializer, it will be initialized after before the first constructor call.
    val nonStatic as string = "123";

    //If an instance variable has no initializer, you can initialize it in the constructor if necessary, even if final.
    val nonStaticTwo as string;

    //A constructor requires all parameters (explicitly typed)
    zenConstructor(parameter as string, parameter2 as string) {

        nonStaticTwo = parameter2;

    //You can have several constructors, but there is no way of constructor chaining.
    zenConstructor(parameter as string) {

    //It is recommended that you explicitly state method's return types as well.
    function myMethod(arg as string, arg1 as string) as string {
        return "value" + arg ~ arg1;


//You call a constructor by calling the class type/name
var test = name("NOPE");
test = name("nope", "noper");
print(test.myMethod("one", "two"));


//You can call statics by the use of the class type/name
print(name("parameter1", "parameter2").nonStatic);

val ttt = name("t");

//You can also call statics by the use of a class instance.
ttt.myStatic = "1";