diff options
author | Aaron Brashears <aaronb@lindenlab.com> | 2007-01-18 00:44:48 +0000 |
---|---|---|
committer | Aaron Brashears <aaronb@lindenlab.com> | 2007-01-18 00:44:48 +0000 |
commit | c189fc0b579352c34285fcf03db4b5bca5cd3804 (patch) | |
tree | ba32536c8bf3b23f311e7ae77aa69f9cbaec4582 /indra/lscript/lscript_library | |
parent | 73f0b5029aa247a563862fc39152ce58baa407aa (diff) |
Result of svn merge -r56700:56797 svn+ssh://svn/svn/linden/branches/more-random into release.
Diffstat (limited to 'indra/lscript/lscript_library')
-rw-r--r-- | indra/lscript/lscript_library/lscript_alloc.cpp | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/indra/lscript/lscript_library/lscript_alloc.cpp b/indra/lscript/lscript_library/lscript_alloc.cpp index 8230d181ce..86c8729e9c 100644 --- a/indra/lscript/lscript_library/lscript_alloc.cpp +++ b/indra/lscript/lscript_library/lscript_alloc.cpp @@ -1100,3 +1100,62 @@ S32 lsa_postadd_lists(U8 *buffer, S32 offset1, LLScriptLibData *data, S32 heapsi return lsa_heap_add_data(buffer, list1, heapsize, TRUE); } + +LLScriptLibData* lsa_randomize(LLScriptLibData* src, S32 stride) +{ + S32 number = src->getListLength(); + if (number <= 0) + { + return NULL; + } + if (stride <= 0) + { + stride = 1; + } + if(number % stride) + { + LLScriptLibData* retval = src->mListp; + src->mListp = NULL; + return retval; + } + S32 buckets = number / stride; + + // Copy everything into a special vector for sorting; + std::vector<LLScriptLibData*> sort_array; + sort_array.reserve(number); + LLScriptLibData* temp = src->mListp; + while(temp) + { + sort_array.push_back(temp); + temp = temp->mListp; + } + + // We cannot simply call random_shuffle or similar algorithm since + // we need to obey the stride. So, we iterate over what we have + // and swap each with a random other segment. + S32 index = 0; + S32 ii = 0; + for(; ii < number; ii += stride) + { + index = ll_rand(buckets) * stride; + for(S32 jj = 0; jj < stride; ++jj) + { + std::swap(sort_array[ii + jj], sort_array[index + jj]); + } + } + + // copy the pointers back out + ii = 1; + temp = sort_array[0]; + while (ii < number) + { + temp->mListp = sort_array[ii++]; + temp = temp->mListp; + } + temp->mListp = NULL; + + src->mListp = NULL; + + LLScriptLibData* ret_value = sort_array[0]; + return ret_value; +} |