Difference between revisions of "LlOverMyLand"

From Second Life Wiki
Jump to navigation Jump to search
m (I'm really begining to load the monospacing)
m (updated comments in example 1)
Line 14: Line 14:
//--// private land message //--//
//--// private land message //--//


//-- @@ = Contains code optimizations, see the following page for details
//-- https://wiki.secondlife.com/wiki/User:Void_Singer/Optimizations
//-- https://wiki.secondlife.com/wiki/User:Void_Singer/Optimizations


Line 30: Line 29:
     sensor( integer vIntFound ){
     sensor( integer vIntFound ){
         do{
         do{
             gKeyAv = llDetectedKey( --vIntFound );  //--@@
             gKeyAv = llDetectedKey( --vIntFound );  //-- Decrement sensor variable to walk backwards through all detections
             //-- check if they are over our land
             //-- check if they are over our land
             if (llOverMyLand( gKeyAv )){ //-- @@
             if (llOverMyLand( gKeyAv )){ //-- the return value is automatically tested by the if statemnt
                 //-- check if they are in the ignore list
                 //-- check if they are in the ignore list
                 if (!~llListFindList( gLstIgnore, (list)llToLower( llDetectedName( vIntFound ) ) )){ //-- @@
                 if (!~llListFindList( gLstIgnore, (list)llToLower( llDetectedName( vIntFound ) ) )){ //-- '!~llListFindList' == 'not found in the list'
                     //-- pester everyone not in the ignore list !!!
                     //-- pester everyone not in the ignore list !!!
                     llInstantMessage( gKeyAv, "You are on private land, please leave this parcel" );
                     llInstantMessage( gKeyAv, "You are on private land, please leave this parcel" );

Revision as of 16:01, 29 December 2012

Summary

Function: integer llOverMyLand( key id );
0.0 Forced Delay
10.0 Energy

Returns an integer boolean, TRUE if id is over land owned by the script owner, FALSE otherwise.

• key id group, avatar or object UUID that is in the same region

On group deeded land the object containing the script must be deeded to the same group. (It is not enough to set the script to the group.)

Examples

<lsl> //--// private land message //--//

//-- https://wiki.secondlife.com/wiki/User:Void_Singer/Optimizations

//-- list of people not to pester, lower case only list gLstIgnore = ["void singer"]; key gKeyAv;

default{

   state_entry(){
       llOwnerSay( "I'll pester anyone on your land I can find,"
                   + " unless they're in your ignore list." );
       llSensorRepeat( "", "", AGENT, 96, PI, 30 );
   }
   sensor( integer vIntFound ){
       do{
           gKeyAv = llDetectedKey( --vIntFound );  //-- Decrement sensor variable to walk backwards through all detections
            //-- check if they are over our land
           if (llOverMyLand( gKeyAv )){ //-- the return value is automatically tested by the if statemnt
                //-- check if they are in the ignore list
               if (!~llListFindList( gLstIgnore, (list)llToLower( llDetectedName( vIntFound ) ) )){ //-- '!~llListFindList' == 'not found in the list'
                    //-- pester everyone not in the ignore list !!!
                   llInstantMessage( gKeyAv, "You are on private land, please leave this parcel" );
               }
           }
       }while (vIntFound);
   }

} </lsl>

This following example is a variation of the previous one. It will email you a daily visitor log. This is useful to determine how much traffic your parcel is attracting each day, and who is visiting you regularly. The llOverMyLand function is used to prevented the script from counting people on other parcels.

<lsl> // This script will email you a daily count of new visitors and repeat visitors. // Visitors are counted once per email update cycle.

// ----------------------------------- // Configuration: customize this script here. // Change this to your email address. string MyEmail = "you@example.com"; // This is a number 0 to 96 meters, anything farther away than that will not be noticed. float SensorRange = 96.0; // How often to send email updates. integer UpdateFrequency = 86400; // Number of seconds in 1 day. // -----------------------------------

// Internal Variables -- Do not change. list todayVisitors = []; list allVisitors = []; list repeatVisitors = []; list firstTimers = []; integer newVisitors = 0; integer returnVisitors = 0; string ParcelName;

default {

   state_entry()
   {
       list parcelDetails = llGetParcelDetails(llGetPos(), [PARCEL_DETAILS_NAME]);
       ParcelName = llList2String(parcelDetails, 0);
       llSensorRepeat( "", "", AGENT, SensorRange, PI, 20);
       llSetTimerEvent(UpdateFrequency); // Email me a regular report.
       llOwnerSay("Visitor Log Started.");
   }

   sensor(integer avsFound)
   {
       key  avKey;
       integer avNum;
       for(avNum=0; avNum<avsFound; avNum++)
       {
           avKey = llDetectedKey(avNum);
           if (llOverMyLand(avKey))
           {
               string whom = llDetectedName(avNum);
               if (!~llListFindList(todayVisitors, [whom]))
               {
                   // This person hasn't been seen yet today.
                   todayVisitors += [whom];
                   if (~llListFindList(allVisitors, [whom]))
                   {
                       // This is a returning visitor.
                       returnVisitors++;
                       repeatVisitors += [whom];
                   }
                   else
                   {
                       // This is a first-time visitor.
                       newVisitors++;
                       allVisitors = [whom] + allVisitors;
                       firstTimers += [whom];
                   }
               }
           }
       }
   }
   
   timer() 
   {
       list parcelDetails = llGetParcelDetails(llGetPos(), [PARCEL_DETAILS_NAME]);
       ParcelName = llList2String(parcelDetails, 0);
       string subj = "Visitor Log for " + ParcelName;
       string body = "Number of Visitors Total: " + (string)(newVisitors + returnVisitors)
           + "\nReturning Visitors: " + (string)returnVisitors
           + "\nNew Visitors: " + (string)newVisitors 
           + "\n\nList of New Visitors:\n\t" + llDumpList2String(firstTimers, "\n\t")
           + "\n\nList of Returning Visitors:\n\t" + llDumpList2String(repeatVisitors, "\n\t");
       newVisitors = 0;
       returnVisitors = 0;
       todayVisitors = [];
       repeatVisitors = [];
       firstTimers = [];
       if (llGetListLength(allVisitors)>500)
       {
           allVisitors = llList2List(allVisitors, 0, 499);
       }
       llEmail(MyEmail, subj, body);
   }

}

</lsl>

Deep Notes

Signature

function integer llOverMyLand( key id );