Revision as of 22:59, 15 May 2011 edit67.188.144.12 (talk) →External links← Previous edit | Revision as of 13:03, 4 August 2011 edit undoSae1962 (talk | contribs)Extended confirmed users3,814 edits Added language template & made minor editsNext edit → | ||
Line 1: | Line 1: | ||
{{infobox programming language | |||
{{TOCright}} | |||
| name = Linden Scripting Language (LSL) | |||
| paradigm = | |||
| year = | |||
| influenced by = ] | |||
| developer = | |||
| latest release version = | |||
| latest release date = | |||
| latest preview version = | |||
| latest preview date = | |||
| typing = ] | |||
| operating system = ] | |||
| file ext = | |||
| license = | |||
| website = {{URL|http://secondlife.mitsi.com/cgi/llscript.plx}} | |||
}} | |||
'''Linden Scripting Language''', or LSL, is the ] used by residents of '']'', a ] by ].<ref>http://wiki.secondlife.com/Help:Getting_started_with_LSL#What_is_LSL.3F</ref> | '''Linden Scripting Language''', or LSL, is the ] used by residents of '']'', a ] by ].<ref>http://wiki.secondlife.com/Help:Getting_started_with_LSL#What_is_LSL.3F</ref> | ||
Line 6: | Line 21: | ||
==LSL design== | ==LSL design== | ||
Linden Scripting Language is a state-] ], in the sense of a ].<ref>http://wiki.secondlife.com/Category:LSL_Events</ref> | Linden Scripting Language is a state-] ], in the sense of a ].<ref>http://wiki.secondlife.com/Category:LSL_Events</ref> | ||
A script consists of variables, function definitions, and one or more named states. Each state contains a description of how to react to events |
A script consists of variables, function definitions, and one or more named states. Each state contains a description of how to react to events that occur while the program is within that state. The system sends events to the script, such as timers, movement, chat (from other agents), email, and collisions (with objects in the virtual world). Scripts can change most aspects of the state of the object and communicate with other objects and agents. As soon as a script is added to an object, and turned on, it begins to execute. | ||
A script is tightly bound to the concept of virtual-world '']'' (in the 3D modeling sense rather than in the ] sense). An object in Second Life represents something like a chair or a wall, or possibly something invisible. Multiple scripts may be placed inside an object, where they all execute simultaneously. | A script is tightly bound to the concept of virtual-world '']'' (in the 3D modeling sense rather than in the ] sense). An object in Second Life represents something like a chair or a wall, or possibly something invisible. Multiple scripts may be placed inside an object, where they all execute simultaneously. | ||
Line 12: | Line 27: | ||
There are over 300 library ]s available.<ref>http://wiki.secondlife.com/Category:LSL_Functions</ref> Users can also define additional functions. LSL is a ]<ref>http://wiki.secondlife.com/Category:LSL_Types</ref> that is compiled to ] before runtime execution in a ] on one of Linden Lab's servers. | There are over 300 library ]s available.<ref>http://wiki.secondlife.com/Category:LSL_Functions</ref> Users can also define additional functions. LSL is a ]<ref>http://wiki.secondlife.com/Category:LSL_Types</ref> that is compiled to ] before runtime execution in a ] on one of Linden Lab's servers. | ||
LSL's native ]s includes ],<ref>http://wiki.secondlife.com/Category:LSL_Integer</ref> ],<ref>http://wiki.secondlife.com/Category:LSL_Float</ref> ],<ref>http://wiki.secondlife.com/Category:LSL_String</ref> keys(]),<ref>http://wiki.secondlife.com/Category:LSL_Key</ref>](used for 3D coordinates and ] color expression),<ref>http://wiki.secondlife.com/Category:LSL_Vector</ref> and ]s (]s).<ref>http://wiki.secondlife.com/Category:LSL_Rotation</ref> There are also heterogeneous lists. There are no arrays; multiple list functions are used to adapt programs requiring array structures.<ref>http://wiki.secondlife.com/List</ref> There is no built-in persistent data storage, such as a file or database. On the other hand, scripts continue to run even when a user is not logged in, and if an object is saved (taken into inventory), and then re-introduced into the |
LSL's native ]s includes ],<ref>http://wiki.secondlife.com/Category:LSL_Integer</ref> ],<ref>http://wiki.secondlife.com/Category:LSL_Float</ref> ],<ref>http://wiki.secondlife.com/Category:LSL_String</ref> keys(]),<ref>http://wiki.secondlife.com/Category:LSL_Key</ref>](used for 3D coordinates and ] color expression),<ref>http://wiki.secondlife.com/Category:LSL_Vector</ref> and ]s (]s).<ref>http://wiki.secondlife.com/Category:LSL_Rotation</ref> There are also heterogeneous lists. There are no arrays; multiple list functions are used to adapt programs requiring array structures.<ref>http://wiki.secondlife.com/List</ref> There is no built-in persistent data storage, such as a file or database. On the other hand, scripts continue to run even when a user is not logged in, and if an object is saved (taken into inventory), and then re-introduced into the World later, it still maintains its previous state. In addition, the mechanisms for communicating via HTTP can be used to store a state externally. | ||
Some functions in LSL have built-in delays, which range from a 0.1-second delay when (for example) requesting string data from a notecard;<ref>https://wiki.secondlife.com/Category:LSL_Notecard An ] data storage medium mainly used for text.</ref> to a 20-second script pause after sending an ]. The delays help prevent developers from writing LSL scripts that could overtax system resources. Memory available to LSL scripts (when compiled as ]) is capped at about 64 ], which places a practical limit on how much a single script can do, however the ability to use multiple scripts and to call scripts from another script allows the user to pragmatically work around this 64 KiB cap. | Some functions in LSL have built-in delays, which range from a 0.1-second delay when (for example) requesting string data from a notecard;<ref>https://wiki.secondlife.com/Category:LSL_Notecard An ] data storage medium mainly used for text.</ref> to a 20-second script pause after sending an ]. The delays help prevent developers from writing LSL scripts that could overtax system resources. Memory available to LSL scripts (when compiled as ]) is capped at about 64 ], which places a practical limit on how much a single script can do, however the ability to use multiple scripts and to call scripts from another script allows the user to pragmatically work around this 64 KiB cap. | ||
Line 26: | Line 41: | ||
* control the agent's camera | * control the agent's camera | ||
The permission system, however, is an issue for scripts owned by the land owner: those scripts can modify the parcel settings without requiring permissions. A malicious script can unsit avatars, ban and unban avatars, destroy the terrain |
The permission system, however, is an issue for scripts owned by the land owner: those scripts can modify the parcel settings without requiring permissions. A malicious script can unsit avatars, ban and unban avatars, destroy the terrain that includes returning of objects by letting them fall out of the World, and gather the ip addresses of avatars by manipulating the media settings for that avatar. | ||
==Default LSL script== | ==Default LSL script== | ||
Line 49: | Line 64: | ||
The revised version of Second Life's scripting virtual machine is based on ], the open source implementation of the Microsoft.NET framework. The Mono VM was introduced to several sims on the Second Life Beta grid for compatibility testing on 29 January 2008 and later that year on 20 August 2008 Linden Lab started deploying it on the production grid<ref>http://blog.secondlife.com/2008/08/20/mono-launch/</ref> - with the entire production grid updated to use it on 29 August 2008. | The revised version of Second Life's scripting virtual machine is based on ], the open source implementation of the Microsoft.NET framework. The Mono VM was introduced to several sims on the Second Life Beta grid for compatibility testing on 29 January 2008 and later that year on 20 August 2008 Linden Lab started deploying it on the production grid<ref>http://blog.secondlife.com/2008/08/20/mono-launch/</ref> - with the entire production grid updated to use it on 29 August 2008. | ||
While the LSL scripting language remained the same, scripts executed on the Mono underpinnings were up to 220<ref>https://jira.secondlife.com/browse/SVC-1341</ref> times faster in execution but at the cost of a somewhat higher overhead when creating (rezzing) scripted objects and moving them from simulator to simulator.<ref>http://jira.secondlife.com/browse/SVC-3895</ref> | While the LSL scripting language remained the same, scripts executed on the Mono underpinnings were up to 220<ref>https://jira.secondlife.com/browse/SVC-1341</ref> times faster in execution, but at the cost of a somewhat higher overhead when creating (rezzing) scripted objects and moving them from simulator to simulator.<ref>http://jira.secondlife.com/browse/SVC-3895</ref> | ||
==References== | |||
⚫ | {{reflist}} | ||
==External links== | ==External links== | ||
Line 59: | Line 77: | ||
* Criticism by Xah Lee | * Criticism by Xah Lee | ||
* - Anyone can edit and contribute scripts. | * - Anyone can edit and contribute scripts. | ||
==Notes== | |||
⚫ | {{reflist}} | ||
<!-- navboxen --> | <!-- navboxen --> | ||
Line 67: | Line 82: | ||
{{Vector graphics markup languages}} | {{Vector graphics markup languages}} | ||
<!-- |
<!--Categories--> | ||
⚫ | ] | ||
] | ] | ||
] | ] | ||
⚫ | ] | ||
<!--Interwikis--> | |||
] | ] | ||
] | ] |
Revision as of 13:03, 4 August 2011
Typing discipline | strong |
---|---|
OS | cross-platform |
Website | secondlife |
Influenced by | |
C |
Linden Scripting Language, or LSL, is the programming language used by residents of Second Life, a virtual world by Linden Lab.
LSL has a syntax similar to C and allows objects to control the behavior of in-world objects of Second Life from the Internet via email, XML-RPC, and most recently, HTTP requests.
LSL design
Linden Scripting Language is a state-event driven scripting language, in the sense of a finite state machine. A script consists of variables, function definitions, and one or more named states. Each state contains a description of how to react to events that occur while the program is within that state. The system sends events to the script, such as timers, movement, chat (from other agents), email, and collisions (with objects in the virtual world). Scripts can change most aspects of the state of the object and communicate with other objects and agents. As soon as a script is added to an object, and turned on, it begins to execute.
A script is tightly bound to the concept of virtual-world objects (in the 3D modeling sense rather than in the object-oriented sense). An object in Second Life represents something like a chair or a wall, or possibly something invisible. Multiple scripts may be placed inside an object, where they all execute simultaneously.
There are over 300 library functions available. Users can also define additional functions. LSL is a strongly typed language that is compiled to bytecode before runtime execution in a virtual machine on one of Linden Lab's servers.
LSL's native data structures includes integers, floating point numbers, strings, keys(UUID),vectors(used for 3D coordinates and RGB color expression), and rotations (quaternions). There are also heterogeneous lists. There are no arrays; multiple list functions are used to adapt programs requiring array structures. There is no built-in persistent data storage, such as a file or database. On the other hand, scripts continue to run even when a user is not logged in, and if an object is saved (taken into inventory), and then re-introduced into the World later, it still maintains its previous state. In addition, the mechanisms for communicating via HTTP can be used to store a state externally.
Some functions in LSL have built-in delays, which range from a 0.1-second delay when (for example) requesting string data from a notecard; to a 20-second script pause after sending an e-mail message. The delays help prevent developers from writing LSL scripts that could overtax system resources. Memory available to LSL scripts (when compiled as mono) is capped at about 64 KiB, which places a practical limit on how much a single script can do, however the ability to use multiple scripts and to call scripts from another script allows the user to pragmatically work around this 64 KiB cap.
Permission system
Certain actions in LSL require permissions:
- take money from agent's account
- take agent's controls
- start or stop Animations on agent
- attach/detach from agent
- change links
- track the agent's camera position and rotation
- control the agent's camera
The permission system, however, is an issue for scripts owned by the land owner: those scripts can modify the parcel settings without requiring permissions. A malicious script can unsit avatars, ban and unban avatars, destroy the terrain that includes returning of objects by letting them fall out of the World, and gather the ip addresses of avatars by manipulating the media settings for that avatar.
Default LSL script
The default script, "Hello, Avatar", a hello world program that speaks (streams message to local chat ("heard" (printed) by all viewers (clients) within 20 meters of the task)) when the script is first saved, initialized or reset (in this case, since the command is in the default "state", the first to be run on initialization) or 'touched' (a simple user interaction usually initiated using a mouse click), looks like:
default { state_entry() { llSay(0, "Hello, Avatar!"); } touch_start(integer total_number) { llSay(0, "Touched."); } }
Mono
The revised version of Second Life's scripting virtual machine is based on Mono, the open source implementation of the Microsoft.NET framework. The Mono VM was introduced to several sims on the Second Life Beta grid for compatibility testing on 29 January 2008 and later that year on 20 August 2008 Linden Lab started deploying it on the production grid - with the entire production grid updated to use it on 29 August 2008.
While the LSL scripting language remained the same, scripts executed on the Mono underpinnings were up to 220 times faster in execution, but at the cost of a somewhat higher overhead when creating (rezzing) scripted objects and moving them from simulator to simulator.
References
- http://wiki.secondlife.com/Help:Getting_started_with_LSL#What_is_LSL.3F
- http://wiki.secondlife.com/Category:LSL_Events
- http://wiki.secondlife.com/Category:LSL_Functions
- http://wiki.secondlife.com/Category:LSL_Types
- http://wiki.secondlife.com/Category:LSL_Integer
- http://wiki.secondlife.com/Category:LSL_Float
- http://wiki.secondlife.com/Category:LSL_String
- http://wiki.secondlife.com/Category:LSL_Key
- http://wiki.secondlife.com/Category:LSL_Vector
- http://wiki.secondlife.com/Category:LSL_Rotation
- http://wiki.secondlife.com/List
- https://wiki.secondlife.com/Category:LSL_Notecard An in-world data storage medium mainly used for text.
- http://wiki.secondlife.com/Hello_Avatar
- http://blog.secondlife.com/2008/08/20/mono-launch/
- https://jira.secondlife.com/browse/SVC-1341
- http://jira.secondlife.com/browse/SVC-3895
External links
- LSL forum—Second Life LSL forum
- Extensive Tutorial on LSL—Dr. Dobb's
- LSL Wiki—A community effort to supplement the available LSL documentation
- LSL Portal—A new Wiki hosted by Second Life
- Mono for Second Life – Information regarding the move to Mono
- Linden Scripting Language Problems Criticism by Xah Lee
- Linden Scripting Language Script Repository - Anyone can edit and contribute scripts.
Second Life | |
---|---|
Culture | |
Events and communities | |
Software | |
Related |
Vector graphics markup languages and file formats | |||||
---|---|---|---|---|---|
By type |
| ||||
See also |