Misplaced Pages

Linden Scripting Language: Difference between revisions

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 21:27, 22 June 2010 edit96.20.233.86 (talk) Permission system: reworded one sentence← Previous edit Latest revision as of 16:39, 13 June 2024 edit undoMika1h (talk | contribs)Autopatrolled, Extended confirmed users, File movers, New page reviewers, Rollbackers119,936 edits Changed redirect target from Second Life to Second Life#ContentTag: Redirect target changed 
(49 intermediate revisions by 32 users not shown)
Line 1: Line 1:
#redirect ]
{{TOCright}}
'''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> LSL scripts can control the behavior of in-world objects. LSL has a syntax similar to ]. LSL allows objects to interact with the ] world and the Internet via email, ], and most recently, ] requests.


{{Rwh}}
==LSL design==
{{R to section}}
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 which 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.

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 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 KB 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 which 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",<ref>http://wiki.secondlife.com/Hello_Avatar</ref> a ] that speaks when the script is first saved, initialized or reset (in this case, since the command is in the default "state") or 'touched' (a simple user interaction usually initiated using a mouse click) , looks like:

<span style='color:darkred'>default</span>
<span style='color:black'>{</span>
<span style='color:darkblue'>state_entry</span><span style='color:black'>()</span>
<span style='color:black'>{</span>
<span style='color:darkred'>llSay</span><span style='color:black'>(</span><span style='color:black'>0</span>, "<span style='color:green'>Hello, Avatar!</span>"<span style='color:black'>)</span>;
<span style='color:black'>}</span>
<span style='color:black'> </span>
<span style='color:darkblue'>touch</span><span style='color:black'>(</span><span style='color:green'>integer</span> <span style='color:black'>total_number)</span>
<span style='color:black'>{</span>
<span style='color:darkred'>llSay</span><span style='color:black'>(</span><span style='color:black'>0</span>, "<span style='color:green'>Touched.</span>"<span style='color:black'>)</span>;
<span style='color:black'>}</span>
<span style='color:black'>}</span>

==LSL's future==
Second Life's revised version of its scripting system was originally scheduled for release in the first quarter of 2006, but has been pushed back indefinitely. Linden Lab is still moving forward, however, as evidenced by demonstrations presented at Microsoft. The new engine executing scripts uses ] (the open source implementation of the Microsoft.NET framework) as the virtual machine for scripts running on the servers. On 29 January 2008, Linden Lab released the Mono VM to several sims on the Second Life Beta grid, for compatibility testing with the wide range of existing LSL code. On 20 August 2008, Linden Lab started deploying the Mono VM on several sims on the Second Life production grid.<ref>http://blog.secondlife.com/2008/08/20/mono-launch/</ref> On 29 August 2008, the entire production grid was updated to use the Mono VM.

The LSL scripting language remains the same, but executing on the Mono underpinnings gives up to 220<ref>https://jira.secondlife.com/browse/SVC-1341</ref> times speed increase, 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>

==External links==
* &mdash;Second Life LSL forum
* &mdash;A community effort to supplement the available LSL documentation
* &mdash;A new Wiki hosted by Second Life
* &ndash; Information regarding the move to Mono
* Criticism by Xah Lee
* - Anyone can edit and contribute scripts.

==Notes==
{{reflist}}

<!-- navboxen -->
{{Second Life}}
{{Vector graphics markup languages}}

<!-- categories -->
] ]
] ]
]

]
]
]
]

Latest revision as of 16:39, 13 June 2024

Redirect to:

  • With history: This is a redirect from a page containing substantive page history. This page is kept as a redirect to preserve its former content and attributions. Please do not remove the tag that generates this text (unless the need to recreate content on this page has been demonstrated), nor delete this page.
    • This template should not be used for redirects having some edit history but no meaningful content in their previous versions, nor for redirects created as a result of a page merge (use {{R from merge}} instead), nor for redirects from a title that forms a historic part of Misplaced Pages (use {{R with old history}} instead).
Categories: