Class FreeplaneScriptBaseClass

java.lang.Object
groovy.lang.GroovyObjectSupport
groovy.lang.Script
org.freeplane.plugin.script.FreeplaneScriptBaseClass
All Implemented Interfaces:
groovy.lang.GroovyObject

public abstract class FreeplaneScriptBaseClass extends groovy.lang.Script
All methods of this class are available as "global" methods in every script. Only documented methods are meant to be used in scripts.

The following global objects are provided as shortcuts by the binding of this class:

The following classes may also be useful in scripting:
  • FreeplaneVersion
  • Constructor Details

    • FreeplaneScriptBaseClass

      public FreeplaneScriptBaseClass()
    • FreeplaneScriptBaseClass

      public FreeplaneScriptBaseClass(groovy.lang.Binding binding)
  • Method Details

    • setBinding

      public void setBinding(groovy.lang.Binding binding)
      Overrides:
      setBinding in class groovy.lang.Script
    • createBinding

      protected groovy.lang.Binding createBinding(NodeRO nodeProxy, ControllerRO controllerProxy)
    • getProperty

      public Object getProperty(String property)
      Specified by:
      getProperty in interface groovy.lang.GroovyObject
      Overrides:
      getProperty in class groovy.lang.Script
    • invokeMethod

      public Object invokeMethod(String methodName, Object args)
      Specified by:
      invokeMethod in interface groovy.lang.GroovyObject
      Overrides:
      invokeMethod in class groovy.lang.Script
    • N

      public NodeRO N(String id)
      Shortcut for node.map.node(id) - necessary for ids to other maps.
    • T

      public String T(String id)
      Shortcut for node.map.node(id).text.
    • V

      public Object V(String id)
      Shortcut for node.map.node(id).value.
    • ifNull

      public Object ifNull(Object value, Object valueIfNull)
      returns valueIfNull if value is null and value otherwise.
    • round

      public Long round(Double d)
      rounds a number to integral type.
    • round

      public Double round(Double d, int precision)
      round to the given number of decimal places: round(0.1234, 2) → 0.12
    • parse

      public Object parse(String text)
      parses text to the proper data type, if possible, setting format to the standard. Parsing is configured via config file scanner.xml
       assert parse('2012-11-30') instanceof Date
       assert parse('1.22') instanceof Number
       // if parsing fails the original string is returned
       assert parse('2012XX11-30') == '2012XX11-30'
      
       def d = parse('2012-10-30')
       c.statusInfo = "${d} is ${new Date() - d} days ago"
       
    • format

      public Object format(Object object, String formatString)
      uses formatString to return a FormattedObject.

      Note: If you want to format the node core better use the format node attribute instead:

       node.object = new Date()
       node.format = 'dd/MM/yy'
       
      Returns:
      IFormattedObject if object is formattable and the unchanged object otherwise.
    • format

      public Object format(Object object)
      Applies default date-time format for dates or default number format for numbers. All other objects are left unchanged.
      Returns:
      IFormattedObject if object is formattable and the unchanged object otherwise.
    • formatDate

      public Object formatDate(Date date)
      Applies default date format (instead of standard date-time) format on the given date.
      Returns:
      IFormattedObject if object is formattable and the unchanged object otherwise.
    • toString

      public String toString(Object o)
      formats according to the internal standard, that is the conversion will be reversible for types that are handled special by the scripting api namely Dates and Numbers.
      See Also:
    • loadUri

      public void loadUri(URI uri)
      opens a URI
    • loadUri

      public void loadUri(String link)
      opens a link
    • toString

      public String toString()
      Overrides:
      toString in class Object