llGetObjectPermMask

From Second Life Wiki
Revision as of 00:26, 9 June 2014 by Omei Qunhua (talk | contribs) (SLuniverse vote)
Jump to navigation Jump to search

Summary

Function: integer llGetObjectPermMask( integer category );
0.0 Forced Delay
10.0 Energy

Returns a bit field (an integer) of the requested permission category for the object containing this script.

• integer category MASK_* flag

Category Description
MASK_BASE 0 The base permissions.
MASK_OWNER 1 Current owner permissions.
MASK_GROUP 2 Active group permissions.
MASK_EVERYONE 3 Permissions everyone has.
MASK_NEXT 4 Permissions the next owner will have.
MASK_COMBINED 16 Include object inventory contents when calculating perms.

Combine with other mask flags, for instance MASK_OWNER|MASK_COMBINED

Permissions Value Description
PERM_ALL 0x7FFFFFFF Move/Modify/Copy/Transfer permissions
PERM_COPY 0x00008000 Copy permission
PERM_MODIFY 0x00004000 Modify permission
PERM_MOVE 0x00080000 Move permission
PERM_TRANSFER 0x00002000 Transfer permission

Examples

<lsl> if ((permsYouHave & permsYouWant) == permsYouWant)

   llSay(0, "You have the perms you want.");

else

   llSay(0, "You don't have the perms you want.");

</lsl> <lsl> integer ownerPerms = llGetObjectPermMask(MASK_OWNER);

integer copyAndModPerms = PERM_COPY

Notes

The perms of a newly created object are often:

 Base = PERM_ALL
 Owner = PERM_ALL
 Next = PERM_MOVE or PERM_TRANSFER
 Group = 0 (none)
 Everyone = 0 (none)

See Also

Functions

•  llGetInventoryPermMask

Articles

•  hex

Deep Notes

Tests

•  llGetObjectPermMask_Test

Signature

function integer llGetObjectPermMask( integer category );