2007-03-22 10:30:00 -07:00
|
|
|
# ***** BEGIN LICENSE BLOCK *****
|
|
|
|
# Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
#
|
|
|
|
# The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
# 1.1 (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.mozilla.org/MPL/
|
|
|
|
#
|
|
|
|
# Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
# for the specific language governing rights and limitations under the
|
|
|
|
# License.
|
|
|
|
#
|
|
|
|
# The Original Code is Google Safe Browsing.
|
|
|
|
#
|
|
|
|
# The Initial Developer of the Original Code is Google Inc.
|
|
|
|
# Portions created by the Initial Developer are Copyright (C) 2006
|
|
|
|
# the Initial Developer. All Rights Reserved.
|
|
|
|
#
|
|
|
|
# Contributor(s):
|
|
|
|
# Aaron Boodman <aa@google.com> (original author)
|
|
|
|
#
|
|
|
|
# Alternatively, the contents of this file may be used under the terms of
|
|
|
|
# either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
|
|
# the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
# in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
# of those above. If you wish to allow use of your version of this file only
|
|
|
|
# under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
# use your version of this file under the terms of the MPL, indicate your
|
|
|
|
# decision by deleting the provisions above and replace them with the notice
|
|
|
|
# and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
# the provisions above, a recipient may use your version of this file under
|
|
|
|
# the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
#
|
|
|
|
# ***** END LICENSE BLOCK *****
|
|
|
|
|
|
|
|
|
2007-06-02 09:59:52 -07:00
|
|
|
/**
|
|
|
|
* lang.js - Some missing JavaScript language features
|
2007-03-22 10:30:00 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2007-06-17 04:35:36 -07:00
|
|
|
* Partially applies a function to a particular "this object" and zero or
|
2007-06-02 09:59:52 -07:00
|
|
|
* more arguments. The result is a new function with some arguments of the first
|
|
|
|
* function pre-filled and the value of |this| "pre-specified".
|
|
|
|
*
|
|
|
|
* Remaining arguments specified at call-time are appended to the pre-
|
|
|
|
* specified ones.
|
|
|
|
*
|
|
|
|
* Usage:
|
2007-06-17 04:35:36 -07:00
|
|
|
* var barMethBound = BindToObject(myFunction, myObj, "arg1", "arg2");
|
2007-06-02 09:59:52 -07:00
|
|
|
* barMethBound("arg3", "arg4");
|
|
|
|
*
|
2007-06-17 04:35:36 -07:00
|
|
|
* @param fn {string} Reference to the function to be bound
|
|
|
|
*
|
|
|
|
* @param self {object} Specifies the object which |this| should point to
|
2007-06-02 09:59:52 -07:00
|
|
|
* when the function is run. If the value is null or undefined, it will default
|
|
|
|
* to the global object.
|
|
|
|
*
|
2007-06-17 04:35:36 -07:00
|
|
|
* @returns {function} A partially-applied form of the speficied function.
|
2007-03-22 10:30:00 -07:00
|
|
|
*/
|
2007-06-17 04:35:36 -07:00
|
|
|
function BindToObject(fn, self, opt_args) {
|
|
|
|
var boundargs = fn.boundArgs_ || [];
|
|
|
|
boundargs = boundargs.concat(Array.slice(arguments, 2, arguments.length));
|
2007-06-02 09:59:52 -07:00
|
|
|
|
2007-06-17 04:35:36 -07:00
|
|
|
if (fn.boundSelf_)
|
2007-06-02 09:59:52 -07:00
|
|
|
self = fn.boundSelf_;
|
2007-06-17 04:35:36 -07:00
|
|
|
if (fn.boundFn_)
|
2007-06-02 09:59:52 -07:00
|
|
|
fn = fn.boundFn_;
|
|
|
|
|
|
|
|
var newfn = function() {
|
|
|
|
// Combine the static args and the new args into one big array
|
2007-06-17 04:35:36 -07:00
|
|
|
var args = boundargs.concat(Array.slice(arguments));
|
2007-06-02 09:59:52 -07:00
|
|
|
return fn.apply(self, args);
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
2007-06-02 09:59:52 -07:00
|
|
|
|
|
|
|
newfn.boundArgs_ = boundargs;
|
|
|
|
newfn.boundSelf_ = self;
|
|
|
|
newfn.boundFn_ = fn;
|
|
|
|
|
|
|
|
return newfn;
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
|
|
|
|
2007-06-02 09:59:52 -07:00
|
|
|
/**
|
|
|
|
* Inherit the prototype methods from one constructor into another.
|
|
|
|
*
|
|
|
|
* Usage:
|
|
|
|
*
|
|
|
|
* function ParentClass(a, b) { }
|
|
|
|
* ParentClass.prototype.foo = function(a) { }
|
|
|
|
*
|
|
|
|
* function ChildClass(a, b, c) {
|
|
|
|
* ParentClass.call(this, a, b);
|
|
|
|
* }
|
|
|
|
*
|
|
|
|
* ChildClass.inherits(ParentClass);
|
|
|
|
*
|
|
|
|
* var child = new ChildClass("a", "b", "see");
|
|
|
|
* child.foo(); // works
|
|
|
|
*
|
|
|
|
* In addition, a superclass' implementation of a method can be invoked
|
|
|
|
* as follows:
|
|
|
|
*
|
|
|
|
* ChildClass.prototype.foo = function(a) {
|
|
|
|
* ChildClass.superClass_.foo.call(this, a);
|
|
|
|
* // other code
|
|
|
|
* };
|
|
|
|
*/
|
|
|
|
Function.prototype.inherits = function(parentCtor) {
|
|
|
|
var tempCtor = function(){};
|
|
|
|
tempCtor.prototype = parentCtor.prototype;
|
|
|
|
this.superClass_ = parentCtor.prototype;
|
|
|
|
this.prototype = new tempCtor();
|
|
|
|
}
|