Difference between revisions of "LlKeyCountKeyValue"

From Second Life Wiki
Jump to navigation Jump to search
m (fixed broken lsl formatting)
Line 16: Line 16:
*[[llKeyCountKeyValue]]
*[[llKeyCountKeyValue]]
*[[llKeysKeyValue]]
*[[llKeysKeyValue]]
|examples=<lsl>key trans;
|examples=<source lang="lsl2">key trans;
default
default
{
{
Line 43: Line 43:
         }
         }
     }  
     }  
}</lsl>
}</source>
|cat1=Experience
|cat1=Experience
|cat2=Dataserver
|cat2=Dataserver
|cat3=Experience/Data
|cat3=Experience/Data
}}
}}

Revision as of 05:43, 7 February 2015

Summary

Function: key llKeyCountKeyValue( );

Start an asynchronous transaction to request the number of keys in the system.
Returns a handle (a key) that can be used to identify the corresponding dataserver event to determine if this command succeeded or failed and the results.

Specification

Dataserver

The dataserver callback parameters are:

String Components
• integer success A boolean specifying if the transaction succeeded (1) or not (0).
• integer error An XP_ERROR_* flag that describes why the operation failed.
• integer pairs number of keys-value pairs in the key-value store

Examples

key trans;
default
{
    state_entry()
    {
        trans = llKeyCountKeyValue();
    }


    dataserver(key t, string value)
    {
        if (t == trans)
        {
            // our llKeyCountKeyValue transaction is done
            list result = llCSV2List(value);
            if (llList2Integer(result, 0) == 1)
            {
                // data size retrieved
                llSay(0, "Keys in use: "+llList2String(result, 1));
            }
            else
            {
                // key count failed
                llSay(0, "Key-value failed to count keys: " + llList2String(result, 1) );
            }
        }
    } 
}

Deep Notes

Signature

function key llKeyCountKeyValue();