Initializing help system before first use

Examples

Topics covered in this chapter:

Passing values to a Java method

This example demonstrates calling a Java method and returning a value to Mosel.

model MosJvmExample1
  uses "mosjvm"

  parameters
    SRC_VALUE=5
  end-parameters

  writeln(SRC_VALUE, "*2=",
    jvmcallint("com.fico.examples.MathOperations.multiply", SRC_VALUE, 2))
  if jvmstatus=false then
    setmatherr("Java exception: "+ jvmgetexceptionclass)
  end-if
	
end-model

Where the MathOperations class is defined as follows:

package com.fico.examples;

public class MathOperations {
  public static int multiply(int v1,int v2) {
    return v1*v2;
  }
}

Calling a void Java method

This example demonstrates calling a Java method and displaying a value to the Mosel output stream.

model MosJvmExample2
  uses "mosjvm"

  parameters
    SRC_VALUE=5
  end-parameters

  jvmcallvoid("com.fico.examples.MathOperations.multiplyAndDisplay", SRC_VALUE, 2)
  if jvmstatus=false then
    setmatherr("Java exception: "+jvmgetexceptionclass)
  end-if
	
end-model

Where the MathOperations class is defined as follows:

package com.fico.examples;

public class MathOperations {
  public static void multiplyAndDisplay(int v1,int v2) {
    System.out.println("The result of "+v1+"*"+v2+" is "+(v1*v2));
  }
}

Passing an array to a Java method

This example demonstrates passing an array to a Java method and returning a value to Mosel.

model MosJvmExample3
  uses "mosjvm"

  declarations
    MyData: array(range) of real
    result: real
  end-declarations

  ! Create some data
  forall(x in 0..5000) MyData(x) := x*5

  ! Calculate sum
  result := jvmcallreal("com.fico.examples.MathOperations.sumOfArray", MyData)
  if jvmstatus=false then
    setmatherr("Java exception: "+jvmgetexceptionclass)
  end-if

  ! Print result
  writeln("Sum of values = ", result)
	
end-model

Where the MathOperations class is defined as follows:

package com.fico.examples;

public class MathOperations {
  public static double sumOfArray(double[] values) {
    double tot = 0;
    for (double v : values) {
      tot += v;
    }
    return tot;
  }
}

Calling a Java method that returns an Object

This example demonstrates calling a Java method that returns an Object.

model MosJvmExample2
  uses "mosjvm"

  declarations
    o: jvmobject
  end-declarations

  writeln("Creating file")
  o := jvmcallobj("com.fico.examples.FileOperations.createFile")
  if jvmstatus=false then
    setmatherr("Java exception: "+jvmgetexceptionclass)
  end-if
	
  writeln("Deleting file")
  jvmcallvoid("com.fico.examples.FileOperations.deleteFile", o)
  if jvmstatus=false then
    setmatherr("Java exception: "+jvmgetexceptionclass)
  end-if

end-model

Where the FileOperations class is defined as follows:

package com.fico.examples;
import java.io.*;

public class FileOperations {
  public static File createFile() throws IOException {
    File f = (new File("testfile.txt")).getAbsoluteFile();
    try (PrintWriter pw = new PrintWriter(new FileWriter(f))) {
      pw.println("Hello World");
    }
    return f;
  }
  public static void deleteFile(File f) throws IOException {
    if (!f.delete()) throw new IOException("Failed to delete file: "+f);
  }
}

Creating and calling methods on Java objects

This example demonstrates calling a Java method that creates an Object, then calls an instance method on that Object.

model MosJvmExample2
  uses "mosjvm"

  declarations
    o: jvmobject
  end-declarations

  writeln("Creating File object")
  o := jvmnewobj("java.lang.File","myfile.txt")
  if jvmstatus=false then
    setmatherr("Java exception: "+jvmgetexceptionclass)
  end-if
	
  writeln("Absolute file path = ", jvmcallstr(o, "getAbsolutePath"))
  if jvmstatus=false then
    setmatherr("Java exception: "+jvmgetexceptionclass)
  end-if

end-model

© 2001-2025 Fair Isaac Corporation. All rights reserved. This documentation is the property of Fair Isaac Corporation (“FICO”). Receipt or possession of this documentation does not convey rights to disclose, reproduce, make derivative works, use, or allow others to use it except solely for internal evaluation purposes to determine whether to purchase a license to the software described in this documentation, or as otherwise set forth in a written software license agreement between you and FICO (or a FICO affiliate). Use of this documentation and the software described in it must conform strictly to the foregoing permitted uses, and no other use is permitted.