Skip to main content
Version: Next

Variant

Variant is a variable type which allows encapsulating data of any valid regular type in a variable. Typically, this variable type can be used to write generic code returning or receiving values for which the type is not known. This is the case for example for code handling object attributes.

A variant type variable can contain a value of the following data types:

  • blob
  • boolean
  • collection
  • date
  • longint
  • object
  • picture
  • number
  • text
  • time
  • null
  • undefined

A same variant variable can be assigned contents of different types. Unlike regular variable types, the variant variable content type is different from the variant variable type itself. For example:

var variant : variant

variant = "hello world"
vtype = type(variant) // 12 (Is variant)
vtypeVal = valueType(variant) // 2 (Is text)

variant = 42
vtype = type(variant) // 12 (Is variant)
vtypeVal = valueType(variant) // 1 (Is number)

You can use variant variables wherever variables are expected, you only need to make sure than the variable content data type is of the expected type. When accessing variant variables, only their current value is taken into account. For example:

var v,v2,t,t2 : Variant
v = "hello world"
v2 = v //assign variable to another variable

t = type(v) // 12 (Is variant)
t2 = type(v2) // 2 (Is text)

Variant can be used to declare method parameters that can be of various types. In this case, you can build your code by testing the parameter value type, for example:

declare (param : variant)
switch
: (valueType(param) == Is longint)
...
: (valueType(param) == Is text)
...
end
note

When variant variables are not necessary (i.e. when the data type is known), it is recommended to use regular typed variables. Regular typed variables provide better performance, make code more clear and are helpful to prevent bugs related to passing unexpected data types.