Difference between revisions of "LlGetParcelPrimOwners"

From Second Life Wiki
Jump to navigation Jump to search
m
(llGetParcelPrimOwners() will also return the UUID of groups that own objects on the specified parcel.)
 
(18 intermediate revisions by 10 users not shown)
Line 1: Line 1:
{{LSL_Function
{{LSL_Function
|inject-2={{LSL Function/position|pos|region=*}}
|func_id=324|func_sleep=2.0|func_energy=10.0
|func_id=324|func_sleep=2.0|func_energy=10.0
|func=llGetParcelPrimOwners|return_type=list|p1_type=vector|p1_name=pos
|func=llGetParcelPrimOwners|return_type=list|p1_type=vector|p1_name=pos
|func_desc
|func_desc
|return_text=of all residents who own objects on the parcel at '''pos''' and with individual prim counts. <br/>The list is formatted as [ key agentKey1, integer agentCount1, key agentKey2, integer agentCount2, ... ], and sorted by agent [[UUID|key]] with a maximum of 100 strides.
|return_text=of all residents and groups who own objects on the parcel at {{LSLP|pos}} and with individual [http://community.secondlife.com/t5/English-Knowledge-Base/Calculating-land-impact/ta-p/974163 land impact] used. <br/>The list is formatted as <code>[ [[key]] ownerKey1, [[integer]] agentImpact1, [[key]] ownerKey2, [[integer]] agentImpact2, ... ]</code>, and sorted by agent/group [[UUID|key]] with a maximum of 100 strides.
|func_footnote=Requires owner-like permissions for the parcel.
|func_footnote=Requires owner-like permissions for the parcel.
|spec
|spec=
====Ownership====
* If the parcel owner and object owner are the same (including if the object and parcel are both group owned):
** All object owners are returned.
* If the parcel is group owned but the object is owned by a member of the group, the function return depends upon what powers they have been granted:
** If resident has the '{{HoverText|return group owned objects|One of the group member abilities which are set at &quot;Group information&quot; window -&gt; &quot;Members &amp; Roles&quot; tab -&gt; &quot;Abilities&quot; tab -&gt; &quot;Parcel Content&quot; folder.}}' power:
*** The return list includes the group and the LI of objects it owns on the parcel.
** If the resident has the 'return group set objects' power:
*** The return list includes all owners who have objects set to the group on the parcel
** If the resident has the 'return non-group objects' power
*** The return list includes all owners of objects that don't fall into the above two categories.
*If none of the above cases match, an empty list will be returned.
{{Collapsible_Table|collapsed=*|table-style=width:100%;|title-style=text-align:left;|title=<h5 style="margin-top:0;">Pseudocode</h5>|content={{!}} Pseudocode written in Javascript
<source lang="javascript">
if(parcel_owner == object_owner)
    return all;
var r = [];
if((parcel_owner is Group) && (object_owner in parcel_owner.members))
{
  if("return group owned objects" in parcel_owner.members[object_owner].powers)
    r = r.concat(group_owned_stride);
  if("return group set objects" in parcel_owner.members[object_owner].powers)
    r = r.concat(group_set_strides);
  if("return non-group objects" in parcel_owner.members[object_owner].powers)
    r = r.concat(non_group_strides);
}
return r;
</source>
}}
|caveats=
|caveats=
* If the object owner is the same as the parcel owner (including if the object and parcel are both group owned) it will get all object owners.
* Function WILL NOT work on group owned land if the owner of the object where this function resides is not currently online and connected to the sim (although now seems to be working for land owner on privately owned land even when the owner is not around).
* If not and the parcel is group owned:
**These limitation can be overcome by [[deed]]ing the object to a group the object owner is one of the owners of
** If the resident has the 'return group owned objects' power, return a list of just the group if there are any group owned objects on the parcel.
**Remember to take a copy before deeding because you cannot undeed something.
** If the resident has the 'return group set objects' power return a list of all owners who have objects set to the group on the parcel
** If the resident has the 'return non-group objects' power return a list of all owners of objects that don't fall into the above
*If none of the above cases match, an empty list will be returned
|constants
|constants
|examples=
|examples=
<lsl>
Show a comma separated list of user IDs and their prim counts.
// Script by Falados Kapuskas
key1, count1, key2, count2 .... etc.
<source lang="lsl2">
 
default
{
    state_entry()
    {
        list TempList = llGetParcelPrimOwners( llGetPos() );
        llSay(0, llList2CSV(TempList) );
    }
}
</source>
 
Use floating text to show prim owner names and counts in count order
 
<source lang="lsl2">
// Show a floating text list of prim owners on this parcel,
// Sorted by prim count per owner. Highest users first.
// Omei Qunhua


// The object has the same permisions to view prim parcel owners
// The object has the same permisions to view prim parcel owners
Line 25: Line 69:
// If the prim is deeded to the right group, it should always get a full list
// If the prim is deeded to the right group, it should always get a full list


// Note: Only works when the when the owner is in the Sim
// Note: Only works on group owned land when the object owner is in the Sim
//      Deeded objects always work (group is always online?)
//      Deeded objects always work (group is always online?)


// -- SETTINGS (Edit These!) -- //
list   gListCountsAndOwners;       // Sorted list count+owner pairs
 
list   gListNamesAndCounts;       // List of owner names + prim counts
integer REFRESH_TIMER = 600;            // Refresh Time (in seconds)
integer gOffset;
vector  PARCEL_POS    = <128,128,0>;   // A Region coordinate of a point in the parcel
integer gIndex;
integer PAGE_SIZE    = 8;              // Number of owners to display per page on the prim
key    gDataserverID;
integer DATA_TIMEOUT  = 10;             // Number of seconds to wait before giving up on dataserver events
integer gListLength;
 
// -- END SETTINGS -- //
 
list gQueryKeys;
list gQueryIndex;
list gNames;
list gPrims;
 
key gDataserver_Name;
 
integer gPageNumber;
integer gPageMax;
//Updates the internal list of prim owners
//Returns TRUE if there were prim owners
//Returns FALSE if the prim owner list was empty
integer UpdateOwnerList()
{
    list owner_prim = llGetParcelPrimOwners(PARCEL_POS);
    //Empty List either means no prims in the parcel
    //Or we couldn't get the list.  The latter is more likely
    if( owner_prim == [] )
    {
        llSetText("[ERROR]\n Couldn't get Parcel Prim Owners",<1,0,0>,1.0);
        return FALSE;
    }
    integer i;
    integer n = llGetListLength(owner_prim) / 2;
   
    //Reset the lists
    gPrims = [];
    gNames = [];
    gQueryKeys = [];
    gQueryIndex = [];
   
   
    for( i = 0; i < n; ++i)
    {
        key owner = llList2Key(owner_prim,i*2);
        string name = llKey2Name(owner);
        if( name == "" ) { //Not in the sim
       
            //Add to the query list
            gNames += ["[Unknown]"];
            gQueryIndex += [llGetListLength(gNames) - 1];
            gQueryKeys += [owner];
        } else {
            gNames += [name];
        }
        gPrims += llList2Integer(owner_prim,i*2+1);
    }
     gPageNumber = 0;
    gPageMax = llCeil( (float)llGetListLength(gNames) / PAGE_SIZE );
    return TRUE;
}
 


// Shows the prim owners starting at index 9*page
// Returns TRUE if there are more pages
// Returns FALSE otherwise
integer ShowPrimOwners(integer page)
{
    integer len = llGetListLength(gNames);
    integer offset = len-page*PAGE_SIZE;
    if(  offset < 0 )
    {
        return FALSE;
    }
    integer i;
   
    integer end = (integer)( llListStatistics(LIST_STAT_MIN,[len,(page+1)*PAGE_SIZE]) );
    string text;
    for( i = PAGE_SIZE*page; i < end; ++i)
    {
        text += llList2String(gNames,i) + " - " + (string)llList2Integer(gPrims,i) + "\n";
    }
    llSetText(text,<1,1,1>,1.0);
    return TRUE;
}
// Set-up phase
default
default
{
{
     state_entry()
     state_entry()
     {
     {
         llSetText("",<1,1,1>,1.0);
         llSetText("Parcel Prim Owner List\n", <1,1,1>, 1);
         if(UpdateOwnerList())
         list TempList = llGetParcelPrimOwners( llGetPos() );
        gListLength= llGetListLength(TempList);     
        if (!gListLength)
         {
         {
             if( gQueryKeys == [] )
             llSetText("[ERROR]\n Couldn't get Parcel Prim Owners", <1,0,0>, 1);
        }
        else
        {
            // Produce a copy of the list suitable for sorting by count, i.e. count then key
            integer x;
            for ( ; x < gListLength; x += 2)
             {
             {
                 state display;
                 gListCountsAndOwners += llList2Integer(TempList, x+1);
            } else {
                 gListCountsAndOwners += llList2String(TempList, x);
                 state lookup;
             }
             }
            // Sort the list in descending order of prim count
            gListCountsAndOwners = llListSort(gListCountsAndOwners, 2, FALSE);
            // Lookup each owner's name. Start at the beginning of our sorted list
            gDataserverID = llRequestAgentData( llList2String(gListCountsAndOwners, 1), DATA_NAME );
         }
         }
     }
     }
    // If there is an error, touch to reset
    touch_start(integer i){llResetScript();}
}


// Display the list
     dataserver( key request_id, string data)
// Allow page flipping via touch
state display
{
     state_entry()
    {
        ShowPrimOwners(gPageNumber);
        llSetTimerEvent(REFRESH_TIMER);
    }
    touch_start(integer i)
     {
     {
         if( !ShowPrimOwners(++gPageNumber) )
        string TempStr = "Parcel Prim Owner List\n";
         if ( request_id == gDataserverID )
         {
         {
             gPageNumber = 0;
             gListNamesAndCounts += data;
             ShowPrimOwners(0);
             gListNamesAndCounts += llList2String(gListCountsAndOwners, gIndex); // process the count as a string
        }
    }
    timer()
    {
        state default;
    }
}


// Look up all names for people that are not in the sim
            gIndex += 2;              // bump through the strided list
// Go to the display state when finished
            if (gIndex < gListLength )
state lookup
            {
{
                // lookup name of next owner in our list
    state_entry()
                gDataserverID = llRequestAgentData( llList2String(gListCountsAndOwners, gIndex +1) , DATA_NAME );
    {
            }
        if( gQueryKeys == [] ) state display;
            integer x;
        llSetTimerEvent(DATA_TIMEOUT);
             for (; x < 16; x+=2)       // show an 8-name subset of the list, starting at 'gOffset'
        gDataserver_Name = llRequestAgentData( llList2Key(gQueryKeys,0) , DATA_NAME );
    }
    dataserver( key request_id, string data)
    {
        if( request_id == gDataserver_Name )
        {
             llSetText("Loading Names .. " + (string)llGetListLength(gQueryKeys),<1,.5,0>,1.0);
            if( llStringTrim(data,STRING_TRIM) != "" )
             {
             {
                 integer i = llList2Integer(gQueryIndex,0);
                 // If we run off the end of the list, we just pick up nulls, so no harm done
                 gNames = llListReplaceList(gNames,[data],i,i);
                 TempStr += llList2String(gListNamesAndCounts, gOffset+x) + " : " + llList2String(gListNamesAndCounts, gOffset+x+1) + "\n";
             }
             }
             gQueryKeys = llDeleteSubList(gQueryKeys,0,0);
             llSetText(TempStr, <1,1,1>, 1);
            gQueryIndex = llDeleteSubList(gQueryIndex,0,0);
             if ( (gListNamesAndCounts != []) > 14)      // If list is longer than 14 (7 owners + counts) ...
           
             if( gQueryKeys != [] )
             {
             {
                 llSetTimerEvent(DATA_TIMEOUT);
                 gOffset += 2;   // scroll the list forwards
                 gDataserver_Name = llRequestAgentData( llList2Key(gQueryKeys,0) , DATA_NAME );
                 llSleep(2);     // at 2 second intervals
            } else {
                state display;
             }
             }
         }
         }
     }
     }
     timer()
 
     touch_start(integer total_number)
     {
     {
         //Skip it, move on
         llResetScript();       // On touch, start the whole process over again
        gQueryKeys = llDeleteSubList(gQueryKeys,0,0);
        gQueryIndex = llDeleteSubList(gQueryIndex,0,0);
        gDataserver_Name = llRequestAgentData( llList2Key(gQueryKeys,0) , DATA_NAME );
     }
     }
}</lsl>
}
</source>
|helpers
|helpers
|also_functions
|also_functions

Latest revision as of 17:58, 8 January 2020

Summary

Function: list llGetParcelPrimOwners( vector pos );
2.0 Forced Delay
10.0 Energy

Returns a list of all residents and groups who own objects on the parcel at pos and with individual land impact used.
The list is formatted as [ key ownerKey1, integer agentImpact1, key ownerKey2, integer agentImpact2, ... ], and sorted by agent/group key with a maximum of 100 strides.

• vector pos position in region coordinates

Requires owner-like permissions for the parcel.

Specification

Ownership

  • If the parcel owner and object owner are the same (including if the object and parcel are both group owned):
    • All object owners are returned.
  • If the parcel is group owned but the object is owned by a member of the group, the function return depends upon what powers they have been granted:
    • If resident has the 'return group owned objects' power:
      • The return list includes the group and the LI of objects it owns on the parcel.
    • If the resident has the 'return group set objects' power:
      • The return list includes all owners who have objects set to the group on the parcel
    • If the resident has the 'return non-group objects' power
      • The return list includes all owners of objects that don't fall into the above two categories.
  • If none of the above cases match, an empty list will be returned.
Pseudocode
Pseudocode written in Javascript
if(parcel_owner == object_owner)
    return all;
var r = [];
if((parcel_owner is Group) && (object_owner in parcel_owner.members))
{
  if("return group owned objects" in parcel_owner.members[object_owner].powers)
    r = r.concat(group_owned_stride);
  if("return group set objects" in parcel_owner.members[object_owner].powers)
    r = r.concat(group_set_strides);
  if("return non-group objects" in parcel_owner.members[object_owner].powers)
    r = r.concat(non_group_strides);
}
return r;

Caveats

  • This function causes the script to sleep for 2.0 seconds.
  • Function WILL NOT work on group owned land if the owner of the object where this function resides is not currently online and connected to the sim (although now seems to be working for land owner on privately owned land even when the owner is not around).
    • These limitation can be overcome by deeding the object to a group the object owner is one of the owners of.
    • Remember to take a copy before deeding because you cannot undeed something.

Examples

Show a comma separated list of user IDs and their prim counts. key1, count1, key2, count2 .... etc.

default
{
    state_entry()
    {
        list TempList = llGetParcelPrimOwners( llGetPos() );
        llSay(0, llList2CSV(TempList) );
    }
}

Use floating text to show prim owner names and counts in count order

// Show a floating text list of prim owners on this parcel,
// Sorted by prim count per owner. Highest users first.
// Omei Qunhua

// The object has the same permisions to view prim parcel owners
// as its owner (In About Land >> Objects >> Object Owners )

// Example: If you can't return group object, you won't see group objects
// If you can't return any objects, an empty list will be returned.
// If the prim is deeded to the right group, it should always get a full list

// Note: Only works on group owned land when the object owner is in the Sim
//       Deeded objects always work (group is always online?)

list    gListCountsAndOwners;       // Sorted list count+owner pairs
list    gListNamesAndCounts;        // List of owner names + prim counts
integer gOffset;
integer gIndex;
key     gDataserverID;
integer gListLength;

default
{
    state_entry()
    {
        llSetText("Parcel Prim Owner List\n", <1,1,1>, 1);
        list TempList = llGetParcelPrimOwners( llGetPos() );
        gListLength= llGetListLength(TempList);      
        if (!gListLength)
        {
            llSetText("[ERROR]\n Couldn't get Parcel Prim Owners", <1,0,0>, 1);
        }
        else
        {
            // Produce a copy of the list suitable for sorting by count, i.e. count then key 
            integer x;
            for ( ; x < gListLength; x += 2)
            {
                gListCountsAndOwners += llList2Integer(TempList, x+1);
                gListCountsAndOwners += llList2String(TempList, x);
            }
            // Sort the list in descending order of prim count
            gListCountsAndOwners = llListSort(gListCountsAndOwners, 2, FALSE);
            // Lookup each owner's name. Start at the beginning of our sorted list
            gDataserverID = llRequestAgentData( llList2String(gListCountsAndOwners, 1), DATA_NAME );
        }
    }

    dataserver( key request_id, string data)
    {
        string TempStr = "Parcel Prim Owner List\n";
        if ( request_id == gDataserverID )
        {
            gListNamesAndCounts += data;
            gListNamesAndCounts += llList2String(gListCountsAndOwners, gIndex);  // process the count as a string

            gIndex += 2;               // bump through the strided list
            if (gIndex < gListLength )
            {
                // lookup name of next owner in our list
                gDataserverID = llRequestAgentData( llList2String(gListCountsAndOwners, gIndex +1) , DATA_NAME );
            }
            integer x;
            for (; x < 16; x+=2)       // show an 8-name subset of the list, starting at 'gOffset'
            {
                // If we run off the end of the list, we just pick up nulls, so no harm done
                TempStr += llList2String(gListNamesAndCounts, gOffset+x) + " : " + llList2String(gListNamesAndCounts, gOffset+x+1) + "\n";
            }
            llSetText(TempStr, <1,1,1>, 1);
            if ( (gListNamesAndCounts != []) > 14)       // If list is longer than 14 (7 owners + counts) ...
            {
                gOffset += 2;   // scroll the list forwards
                llSleep(2);     // at 2 second intervals
            }
        }
    }

    touch_start(integer total_number)
    {
        llResetScript();        // On touch, start the whole process over again
    }
}

Deep Notes

Signature

function list llGetParcelPrimOwners( vector pos );