/
foswikiArray_src.js
103 lines (91 loc) · 2.89 KB
/
foswikiArray_src.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/*
Foswiki - The Free and Open Source Wiki, http://foswiki.org/
Copyright (C) 2008-2010 Foswiki Contributors. Foswiki Contributors
are listed in the AUTHORS file in the root of this distribution.
NOTE: Please extend that file, not this notice.
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version. For
more details read LICENSE in the root of this distribution.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
As per the GPL, removal of this notice is prohibited.
*/
var foswiki;
if (foswiki == undefined)
foswiki = {};
/**
* Array utility functions.
*/
foswiki.Array = {
/**
* Removes an object from an Array.
* @param inArray : (required) Array to remove object from
* @param inObject : (required) Object to remove from Array
*/
remove:function(inArray, inObject) {
if (!inArray || !inObject)
return null;
for (i=0; i<inArray.length; i++) {
if (inObject == inArray[i]) {
inArray.splice(i, 1);
}
}
},
/**
* Creates an Array from a list of function arguments.
* @param inArguments : function arguments
* @param inStartIndex : (optional) the starting index in the list
* of function arguments
* @return A new Array with elements from the passed function arguments.
* @use
* The following code creates an Array of all arguments passed after
* inName:
* <pre>
* function releaseProps(inName) {
* var properties = foswiki.Array.convertArgumentsToArray(arguments, 1);
* if (!properties) return;
* _releaseProps(inName, properties);
* }
* </pre>
*/
convertArgumentsToArray:function(inArguments, inStartIndex) {
if (inArguments == undefined)
return null;
var ilen = inArguments.length;
if (ilen == 0)
return null;
var start = 0;
if (inStartIndex) {
if (isNaN(inStartIndex))
return null;
if (inStartIndex > ilen-1)
return null;
start = inStartIndex;
}
var list = [];
for (var i = start; i < ilen; i++) {
list.push(inArguments[i]);
}
return list;
},
/**
* Determine the index of the (first) occurrence of an object in an array.
* @param inArray : (Array) array to search
* @param el : (Object) the object to find
* @return The index number; -1 if the object is not found; null if no
* valid Array has been passed.
*/
indexOf:function(inArray, el) {
if (!inArray || inArray.length == undefined)
return null;
var i, ilen = inArray.length;
for (i=0; i<ilen; ++i) {
if (inArray[i] == el)
return i;
}
return -1;
}
};