/
Global Functions

Global Functions

 

BrightScript provides a set of standard, module-scope functions that are stored in the global object. If a global function is referenced, the compiler directs the runtime to call the appropriate global object member. When calling a global function, you do not need to use the dot operator to reference the roGlobal object.

Global trigonometric functions accept and return values in radians, not degrees.

ifGlobal

CreateObject(name As String) As Object

Creates a BrightScript object corresponding to the specified class name. This method returns invalid if object creation fails. Some objects have parameters in their constructor, which must be passed after the class name in a comma-separated list.

sw = CreateObject("roGpioControlPort") serial = CreateObject("roSerialPort", 0, 9600)
RestartScript() As Void

Exits the current script. The system then scans for a valid autorun.brs file to run.

RestartApplication() As Void

Restarts the BrightSign application.

Sleep(milliseconds As Integer)

Instructs the script to pause for a specified amount of time without wasting CPU cycles. The sleep interval is specified in milliseconds.

asc(letter As String) As Integer

Returns the ASCII code for the first character of the specified string. A null-string argument will cause an error.

chr(character As Integer) As String

Returns a one-character string containing a character reflected by the specified ASCII or control. For example, because quotation marks are normally used as string delimiters, you can pass ASCII code 34 to this function to add quotes to a string.

len(target_string As String) As Integer

Returns the number of characters in a string

str(value As Double) As String

Converts a specified float value to a string. This method also returns a string equal to the character representation of a value. For example, if A is assigned a value of 58.5, then calling str(A) will return "58.5" as a string.

strI(value As Integer) As String

Converts a specified integer value to a string. This method returns a string equal to the character representation of a value, and it will always add a leading space to non-negative numbers. For example, if A is assigned a value of 58.5, then calling stri(A) will return " 58" as a string.

See roInt,roFloat,roString-ToStr()AsString if you need an alternate method that will return the string without the prepended space.

val(target_string As String) As Double

Returns a number represented by the characters in the string argument. This is the opposite of the str() function. For example, if A is assigned the string "58", and B is assigned the string "5", then calling val(A+"."+B) will return the float value 58.5.

strtoi(target_string As String) As Integer

Converts the target string to an integer. Any non-integer characters (including decimal points and spaces), and any numbers to the right of a non-integer character, will not be part of the integer output.

abs(x As Double) As Double

Returns the absolute value of the argument x

atn(x As Double) As Double

Returns the arctangent (in radians) of the argument x (i.e. Atn(x) returns "the angle whose tangent is x"). To get the arctangent in degrees, multiply Atn(x) by 57.29578.

csng(x As Integer) As Float

Returns a single-precision float representation of the argument x

cdbl(x As Integer) As Double

Returns a double-precision float representation of the argument x

cint(x As Double) As Integer

Returns an integer representation of the argument x by rounding to the nearest whole number.

cos(x As Double) As Double

Returns the cosine of the arugment x. The argument must be in radians. To obtain the cosine of x when x is in degrees, use Cos(x*.01745329).

exp(x As Double) As Double

Returns the natural exponential of x. This is the inverse of the log() function.

fix(x As Double) As Integer

Returns a truncated representation of the argument x. All digits to the right of the decimal point are removed so that the resultant value is an integer. For non-negative values of xfix(x) is equal to int(x). For negative values of xfix(x) is equal to int(x)+1.

int(x As Double) As Integer

Returns an integer representation of the argument x using the largest whole number that is not greater than the argument. For example, int(2.2) returns 2, while int(-2.5) returns -3.

log(x As Double) As Double

Returns the natural logarithm of the argument i (i.e. loge(x)). This is the inverse of the exp() function. To find the logarithm of a number to a base b, use the following formula: logb(x) = loge(x)/loge(b).

sgn(x As Double) As Integer

Returns an integer representing how the float argument x is signed: -1 for negative, 0 for zero, and 1 for positive.

sgnI(x As Integer) As Integer

Returns an integer representing how the integer argument x is signed: -1 for negative, 0 for zero, and 1 for positive.

sin(x As Double) As Double

Returns the sine of the argument x. The argument must be in radians. To obtain the sine of x when x is in degrees, use sin(x*.01745329).

tan(x As Double) As Double

Returns the tangent of the argument x. The argument must be in radians. To obtain the tangent of x when x is in degrees, use tan(x*.01745329).

sqr(x As Double) As Double

Returns the square root of the argument x. This function is the same as x^(1/2), but calculates the result faster.

StableEnumeration(array as Object) As Object

Returns an object that represents the iteration. This function does not affect the original object. Must use this function to safely enumerate containers more than once in parallel.

Left(target_string As String, n As Integer) As String

Returns the first n characters of the specified string.

Right(target_string As String, n As Integer) As String

Returns the last n characters of the specified string.

StringI(n As Integer, character As Integer) As String

Returns a string composed of a character symbol repeated n times. The character symbol is passed to the method as an ASCII code integer.

String(n As Integer, character As String) As String

Returns a string composed of a character symbol repeated n times. The character symbol is passed to the method as a string.

Mid(target_string As String, start_position As Integer, length As Integer) As String

Returns a substring of the target string. The first integer passed to the method specifies the starting position of the substring, and the second integer specifies the length of the substring. The start position of a string begins with 1.

Instr(start_position As Integer, search_text As String, substring As String) As Integer 

Returns the position of a substring within a string. This function is case sensitive and returns 0 if the specified substring is not found. The start position of a string begins with 1.

Tip

The string object also offers an Instr() method (though it uses a zero-based index). See the roString documentation for more details.

FindMemberFunction(object as Object, funName as String) As Interface

Returns the interface from the object that provides the specified function, or else returns invalid. It is only available if roDeviceInfo.HasFeature("FindMemberFunction") returns true.

It can be used as shown below:

print FindMemberFunction({}, "Count") '= <Interface: ifAssociativeArray>

ON THIS PAGE

GetInterface(object As Object, ifname As String) As Interface

Returns a value of the type Interface. All objects have one or more interfaces. In most cases, you can skip interface specification when calling an object component. This will not cause problems as long as the method names within a function are unique.

Wait(timeout As Integer, port As Object) As Object

Instructs the script to wait on an object that has an ifMessagePort interface. This method will return the event object that was posted to the message port. If the timeout is specified as zero, Wait() will wait indefinitely; otherwise, Wait() will return Invalid after the specified number of milliseconds if no messages have been received.

p = CreateObject("roMessagePort") sw = CreateObject("roGpioControlPort") sw.SetPort(p) msg=wait(0, p) print type(msg) ' should be roGpioButton print msg.GetInt() ' button number

 

ReadAsciiFile(file_path As String) As String

Reads the specified text file and returns it as a string.

WriteAsciiFile(file_path As String, buffer As String) As Boolean

Creates a text file at the specified file path. The text of the file is passed as the second parameter. This method cannot be used to edit files: A preexisting text file will be overwritten if it has the same name and directory path as the one being created.

The roCreateFile object provides more flexibility if you need to create or edit files.

ListDir(path As String) As Object

Returns an roList object containing the contents of the specified directory path. File names are converted to all lowercase.

MatchFiles(path As String, pattern_in As String) As Object

Takes a directory to look in (it can be as simple as "." or "/") and a pattern to be matched and then returns an roList containing the results. Each listed result contains only the part of the filename that is matched against the pattern, not the full path. The match is only applied in the specified directory; you will get no results if the pattern contains a directory separator. The pattern is a case insensitive wildcard expression. It may contain the following special characters:

  • ? – Matches any single character.

  • * – Matches zero or more arbitrary characters.

  • […] – Matches any single character specified within the brackets. The closing bracket is treated as a member of the character class if it immediately follows the opening bracket (i.e. "[]]" matches a single closed bracket). Within this class, "-" can be used to specify a range unless it is the first or last character (e.g. "[A-Cf-h"] is equivalent to "[ABCfgh]"). A character class may be negated by specifying "^" as the first character. To match a literal of this character, place it elsewhere in the class.

The special characters "?", "*", and "[" lose their function if preceded by a single "\", and a single "\" can be matched using "\\".

 

LCase(target_string As String) As String

Converts the specified string to all lowercase.

UCase(target_string As String) As String

Converts the specified string to all uppercase.

DeleteFile(file_path As String) As Boolean

Deletes the file at the specified file path. This method returns False if the delete operation fails or if the file does not exist.

DeleteDirectory(directory As String) As Boolean

Deletes the specified directory. This method will recursively delete any files and directories that are necessary for removing the specified directory. This method returns False if it fails to delete the directory, but it may still delete some of the nested files or directories.

For example:

dir = DeleteDirectory("/directory") ' Check if directory deletion was successful print dir; ' true if successful

or

dir = DeleteDirectory("/directory") if not dir then print "Could not delete directory" end if
CreateDirectory(directory As String) As Boolean

Creates the specified directory. Only one directory can be created at a time. This method returns True upon success and False upon failure.

For example:

dir = CreateDirectory("/directory") ' Check if directory creation was successful print dir; ' true if successful

or

dir = CreateDirectory("/directory") if not dir then print "Could not create directory" end if
RebootSystem() As Void

Instructs the player to perform a soft reboot.

ShutdownSystem() As Void
 
UpTime(dummy As Integer) As Double

Returns the uptime of the system (in seconds) since the last reboot.

FormatDrive(drive As String, fs_type As String) As Boolean 

Formats the specified drive using one of the file systems listed below. This function returns True upon success and False upon failure:

  • vfat (FAT32, DOS/Windows file system): Readable and writable by Windows, Linux, and MacOS.

  • exfat (DOS/Windows file system): Supported on Series 3 (XTx43, XDx33, HDx23, LS423, HO523) and Series 4 (XTx44, XDx34, HDx24, LS424) players with firmware versions 6.2.94 and later. Secure boot is not supported with the exFAT filesystem on firmware version 6.2.94.

  • ext2 (Linux file system): Writable by Linux and readable by Windows and MacOS with additional software.

  • ext3 (Linux file system): Writable by Linux and readable by Windows and MacOS with additional software. 

  • ext4 (Linux file system): Writable by Linux and readable by Windows and MacOS with additional software. This is the recommended file system for SSD devices and USB hard drives.

EjectDrive(drive As String) As Boolean

Ejects the specified drive (e.g. "SD:") and returns True if successful. If the script is currently accessing files from the specified drive, the ejection process will fail.

CopyFile(source As String, destination As String) As Boolean

Copies the file at the specified source file-path to the specified destination directory. The function returns True if successful and False in the event of failure.

MoveFile(source As String, destination As String) As Boolean

Moves the specified source file to the specified destination directory. The function returns True if successful and False in the event of failure.

Both path names must be on the same drive.

 

MapFilenameToNative(path As String) As String

Converts the specified BrightScript-style path to the corresponding native path and returns it as a string (e.g. the path "SD:/mydir" will be returned as "/storage/sd/mydir").

rnd(a As Dynamic) As Dynamic
RunGarbageCollector() As roAssociativeArray

Destroys objects that are currently in a state of circular reference counting. BrightScript normally removes any objects that become unreferenced as part of its automated garbage collection algorithm. However, objects that reference each other will never reach a reference count of zero, and will need to be destroyed manually using this method.

This method is useful when destroying old presentation data structures and generating a new presentation. This method returns an associative array outlining the results of the garbage-collection process.

GetDefaultDrive() As String

Returns the current default drive complete with a trailing slash. When running as autorun.brs, the drive containing the autorun is designated as the current default.

SetDefaultDrive(drive As String)

Sets the current default drive, which does not need to include a trailing slash. This method does not fail; however, if the specified default drive does not exist, it will not be possible to retrieve anything.

This method accepts the following values:

  • "USB1:" – The drive for USB storage devices connected to the player

  • "SD:" – The primary SD or microSD drive on the player.

  • "SD2:" – The internal microSD drive on the player (4Kx42, XDx32 models only)

  • "SSD:" – The internal SSD on the player (XTx44, XTx34, XDx34, XDx33 models only)

EnableZoneSupport(enable As Boolean)

Allows for display of multiple video, HTML, image, and text zones. As of firmware 6.0.x, zone support is enabled by default.

EnableAudioMixer(enable As Boolean)
Pi() As Double

Returns the value of pi as a double-precision floating-point number.

ParseJson(json_string As String) As Object

Parses a string formatted according to the RFC4627 standard and returns an equivalent BrightScript object, which can consist of the following: Booleans, integers, floating point numbers, strings, roArray objects, and roAssociativeArray objects. The  ParseJson() method has the following properties:

  • Invalid will be returned if the string is not syntactically correct.

  • Any roAssociativeArray objects that are returned will be case sensitive.

  • An error will be returned if an roArray or roAssociativeArray is nested more than 256 levels deep.

The following script demonstrates how to use ParseJson() to process a JSON object containing the titles and URLs of a set of images.

JSON Script
{ "photos" : [ { "title" : "View from the hotel", "url" : "http://example.com/images/00012.jpg" }, { "title" : "Relaxing at the beach", "url" : "http://example.com/images/00222.jpg" }, { "title" : "Flat tire", "url" : "http://example.com/images/00314.jpg" } ] }

 

BrightScript
searchRequest = CreateObject("roUrlTransfer") searchRequest.SetURL("http://api.example.com/services/rest/getPhotos") response = ParseJson(searchRequest.GetToString()) For Each photo In response.photos GetImage(photo.title, photo.url) End For

 

FormatJson(json As roAssociativeArray, flags As Integer) As String

Converts an associative array to a JSON string (i.e. formatted according to the RFC4627 standard). The following are supported data types: Boolean, Integer, Float, String, roArray, and roAssociativeArray. If the flags parameter is set to 0 or not specified, non-ASCII characters are escaped in the output string as “\uXXXX”, where “XXXX” is the hexadecimal representation of the Unicode character value. If the flags parameter is set to 1, non-ASCII characters are not escaped.

If arrays or associative arrays are nested more than 256 levels deep, an error will occur. If an error occurs, an empty string will be returned.

Important

By default, using object-literal syntax (e.g. aa={relativePath:"Foo"}) to generate an associative array will convert keys to all lower case. To preserve camel case for JSON, use the roAssociativeArray.AddReplace() method instead of object literals or call roAssociativeArray.SetModeCaseSensitive() before adding entries.