removed useless _ folders

This commit is contained in:
Fred Beckhusen
2015-08-09 16:54:31 -05:00
parent fde850293c
commit 948a44dfba
5204 changed files with 2425579 additions and 0 deletions

View File

@@ -0,0 +1,3 @@
<Solution name="MultiDimensional_Arrays_in_LSL">
<Project name="MultiDimensional_Arrays_in_LSL" path="MultiDimensional_Arrays_in_LSL\MultiDimensional_Arrays_in_LSL.prj" active="true"/>
</Solution>

View File

@@ -0,0 +1,6 @@
<Project name="MultiDimensional_Arrays_in_LSL" guid="D7E20C23-6C00-1014-B904-200204C60A89">
<Object name="Object" guid="D7E20D01-6C00-1014-B904-200204C60A89">
<Script name="MultiDimensional_Arrays_in_LSL_1.lsl" guid="D7E23316-6C00-1014-B904-200204C60A89">
</Script>
</Object>
</Project>

View File

@@ -0,0 +1,208 @@
// :CATEGORY:Arrays
// :NAME:MultiDimensional_Arrays_in_LSL
// :AUTHOR:Jamethiel Wickentower
// :CREATED:2010-01-10 05:20:56.000
// :EDITED:2013-09-18 15:38:57
// :ID:534
// :NUM:720
// :REV:1.0
// :WORLD:Second Life
// :DESCRIPTION:
// MultiDimensional_Arrays_in_LSL
// :CODE:
// Copyright 2008 Jamethiel Wickentower (David Lloyd)
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// #########################################################################
// This library implements single dimensional and multi-dimensional arrays.
//
// Currently implemented:
//
// * Searching for a value
//
// To be implemented:
//
// * Removing a single value or a whole row
// * Replacing a single value or a whole row
// * Inserting a single value or a whole row
//
// The last operation may not make sense with arrays, though.
//
// This does not handle hash maps.
key gOwner;
string gOwnerName;
list testList = [
1, "DSL-",
"DSL-1", "first", "row", "now",
"DSL-2", "onto", "the", "chocolate", "boards", "we",
"DSL-3", "go", "west"];
list fakeList = [
1, "DSL-"];
list test2Dims = [
2, "DSL-", "LSD-",
"DSL-1",
"LSD-1", "father", "christmas",
"LSD-2", "easter", "bunny",
"LSD-3", "saint", "nicholas"];
list test2Complex = [
"DSL-1",
"LSD-1", "David", "Lloyd",
"LSD-2", "Janet", "Barker",
"DSL-2",
"LSD-1", "None",
"DSL-3",
"LSD-1", "Tony",
"LSD-2", "Barber",
"LSD-3", "Shindig", "Nonce"];
report(string msg) {
llOwnerSay(msg);
}
// jw_auto_array_get
//
// This reads a special array that is setup like this:
//
// item[0] = number of dimensions
// item[0..N] = prefixes
//
// The prefixes MUST be unique and contained within the data or bad things
// will certain happen.
//
// You can search a one dimensional array by giving a single number in the
// needle list.
list jw_auto_array_get(list haystack, list needle) {
integer where;
integer haystack_len = llGetListLength(haystack);
integer needle_len = llGetListLength(needle);
if (haystack_len < 3) {
report("Invalid or empty list.");
return [];
}
integer dimensions = llList2Integer(haystack, 0);
if (dimensions != needle_len) {
report("Invalid haystack length.");
return [];
}
list prefixes = llList2List(haystack, 1, dimensions);
list result = jw_array_recursive(haystack, prefixes, needle, 0);