Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

switch to closure compiler and simplify license.

  • Loading branch information...
commit 4eb1469c049d7a82ce60e71d6a0197cb7de4c7c5 1 parent 2072daf
@millermedeiros authored
View
216 build.xml
@@ -1,114 +1,112 @@
<?xml version="1.0" encoding="utf-8"?>
<project name="js-signals" default="" basedir=".">
-
- <!-- properties -->
-
+
+ <!-- properties -->
+
<property file="dev/build/build.properties" />
-
- <!-- custom tasks -->
-
-
- <!-- targets -->
-
- <target name="-purgeJsDeploy">
- <delete>
- <fileset dir="${dist.dir}" includes="${dist.name} ${dist.min.name}" />
- </delete>
- </target>
-
- <target name="compile" depends="-purgeJsDeploy">
- <echo message="Building ${dist.name}..." />
-
- <buildnumber file="${build.dir}/build.number"/>
-
- <tstamp>
+
+
+ <!-- custom tasks -->
+
+ <taskdef name="jscomp" classname="com.google.javascript.jscomp.ant.CompileTask" classpath="${closure_compiler.jar}"/>
+
+
+ <!-- targets -->
+
+ <target name="-purgeJsDeploy">
+ <delete>
+ <fileset dir="${dist.dir}" includes="${dist.name} ${dist.min.name}" />
+ </delete>
+ </target>
+
+ <target name="compile" depends="-purgeJsDeploy">
+ <echo message="Building ${dist.name}..." />
+
+ <buildnumber file="${build.dir}/build.number"/>
+
+ <tstamp>
<format property="build.date" pattern="yyyy/MM/dd hh:mm aa" unit="hour"/>
- </tstamp>
-
- <loadfile property="license.txt" srcFile="${src.dir}/license.txt"/>
- <loadfile property="signals.js" srcFile="${src.dir}/signals.js"/>
- <loadfile property="SignalBinding.js" srcFile="${src.dir}/SignalBinding.js"/>
- <loadfile property="Signal.js" srcFile="${src.dir}/Signal.js"/>
- <loadfile property="CompoundSignal.js" srcFile="${src.dir}/CompoundSignal.js"/>
-
- <copy file="${src.dir}/wrapper.js" tofile="${dist.dir}/${dist.name}" />
-
- <replace>
- <fileset dir="${dist.dir}" includes="${dist.name}" />
- <replacefilter token="//::LICENSE:://" value="${license.txt}" />
- <replacefilter token="//::SIGNALS_JS:://" value="${signals.js}" />
- <replacefilter token="//::SIGNAL_BINDING_JS:://" value="${SignalBinding.js}" />
- <replacefilter token="//::SIGNAL_JS:://" value="${Signal.js}" />
- <replacefilter token="//::COMPOUND_SIGNAL_JS:://" value="${CompoundSignal.js}" />
- <!-- version number, build number/date should come after other replaces -->
- <replacefilter token="::VERSION_NUMBER::" value="${version.number}" />
- <replacefilter token="::BUILD_NUMBER::" value="${build.number}" />
- <replacefilter token="::BUILD_DATE::" value="${build.date}" />
- </replace>
-
- <echo message="${dist.name} built." />
- </target>
-
- <target name="lint">
- <echo message="JSLinting ${dist.name}..."/>
-
- <apply executable="java">
- <filelist dir="${dist.dir}">
- <file name="${dist.name}"/>
- </filelist>
- <arg line="-jar"/>
- <arg path="${jslint.jar}"/>
- </apply>
-
- <echo message="JSLinted ${dist.name}."/>
- </target>
-
- <target name="minify">
- <echo message="Building ${dist.min.name}..." />
-
- <apply executable="java" parallel="false" verbose="true" dest="${dist.dir}">
- <fileset dir="${dist.dir}">
- <include name="${dist.name}" />
- </fileset>
- <arg line="-jar" />
- <arg path="${yuicompressor.jar}" />
- <arg value="--charset" />
- <arg value="UTF8" />
- <arg value="-v" />
- <arg value="-o" />
- <targetfile />
- <mapper type="glob" from="${dist.name}" to="${dist.min.name}" />
- </apply>
-
- <echo message="${dist.min.name} built." />
- </target>
-
- <target name="-purgeDocs">
- <delete dir="${docs.dir}" />
- <mkdir dir="${docs.dir}"/>
- </target>
-
- <target name="generateDocs" depends="-purgeDocs">
- <echo message="Generating documentation" />
- <apply executable="java" parallel="false" verbose="true">
- <fileset dir="${dist.dir}">
- <include name="${dist.name}" />
- </fileset>
- <arg line="-jar" />
- <arg path="${jsdoc-toolkit.dir}/jsrun.jar" />
- <arg value="${jsdoc-toolkit.dir}/app/run.js" />
- <arg value="-t=${jsdoc-toolkit.dir}/templates/jsdoc-simple" />
- <arg value="-d=${docs.dir}" />
- </apply>
- <echo message="Documentation generated" />
- </target>
-
- <target name="build" depends="compile, lint, minify">
- <echo message="Build Complete." />
- </target>
-
- <target name="deploy" depends="build, generateDocs">
- <echo message="Build Complete." />
- </target>
-
+ </tstamp>
+
+ <loadfile property="license.txt" srcFile="${src.dir}/license.txt"/>
+ <loadfile property="signals.js" srcFile="${src.dir}/signals.js"/>
+ <loadfile property="SignalBinding.js" srcFile="${src.dir}/SignalBinding.js"/>
+ <loadfile property="Signal.js" srcFile="${src.dir}/Signal.js"/>
+ <loadfile property="CompoundSignal.js" srcFile="${src.dir}/CompoundSignal.js"/>
+
+ <copy file="${src.dir}/wrapper.js" tofile="${dist.dir}/${dist.name}" />
+
+ <replace>
+ <fileset dir="${dist.dir}" includes="${dist.name}" />
+ <replacefilter token="//::LICENSE:://" value="${license.txt}" />
+ <replacefilter token="//::SIGNALS_JS:://" value="${signals.js}" />
+ <replacefilter token="//::SIGNAL_BINDING_JS:://" value="${SignalBinding.js}" />
+ <replacefilter token="//::SIGNAL_JS:://" value="${Signal.js}" />
+ <replacefilter token="//::COMPOUND_SIGNAL_JS:://" value="${CompoundSignal.js}" />
+ <!-- version number, build number/date should come after other replaces -->
+ <replacefilter token="::VERSION_NUMBER::" value="${version.number}" />
+ <replacefilter token="::BUILD_NUMBER::" value="${build.number}" />
+ <replacefilter token="::BUILD_DATE::" value="${build.date}" />
+ </replace>
+
+ <echo message="${dist.name} built." />
+ </target>
+
+ <target name="lint">
+ <echo message="JSLinting ${dist.name}..."/>
+
+ <apply executable="java">
+ <filelist dir="${dist.dir}">
+ <file name="${dist.name}"/>
+ </filelist>
+ <arg line="-jar"/>
+ <arg path="${jslint.jar}"/>
+ </apply>
+
+ <echo message="JSLinted ${dist.name}."/>
+ </target>
+
+ <target name="minify">
+ <echo message="Building ${dist.min.name}..." />
+
+ <jscomp compilationLevel="simple" debug="false" output="${dist.dir}/${dist.min.name}">
+ <externs dir="${build.dir}">
+ <file name="externs.js"/>
+ </externs>
+ <sources dir="${dist.dir}">
+ <file name="${dist.name}"/>
+ </sources>
+ </jscomp>
+
+ <echo message="${dist.min.name} built." />
+ </target>
+
+ <target name="-purgeDocs">
+ <delete dir="${docs.dir}" />
+ <mkdir dir="${docs.dir}"/>
+ </target>
+
+ <target name="generateDocs" depends="-purgeDocs">
+ <echo message="Generating documentation" />
+ <apply executable="java" parallel="false" verbose="true">
+ <fileset dir="${dist.dir}">
+ <include name="${dist.name}" />
+ </fileset>
+ <arg line="-jar" />
+ <arg path="${jsdoc-toolkit.dir}/jsrun.jar" />
+ <arg value="${jsdoc-toolkit.dir}/app/run.js" />
+ <arg value="-t=${jsdoc-toolkit.dir}/templates/jsdoc-simple" />
+ <arg value="-d=${docs.dir}" />
+ </apply>
+ <echo message="Documentation generated" />
+ </target>
+
+ <target name="build" depends="compile, lint, minify">
+ <echo message="Build Complete." />
+ </target>
+
+ <target name="deploy" depends="build, generateDocs">
+ <echo message="Build Complete." />
+ </target>
+
</project>
View
4 dev/build/build.number
@@ -1,3 +1,3 @@
#Build Number for ANT. Do not edit!
-#Fri Oct 28 11:59:24 BRST 2011
-build.number=228
+#Fri Oct 28 12:21:45 BRST 2011
+build.number=235
View
5 dev/build/build.properties
@@ -3,10 +3,13 @@ src.dir = ${dev.dir}/src
build.dir = ${dev.dir}/build
dist.dir = dist
docs.dir = ${dist.dir}/docs
+
+closure_compiler.jar = ${build.dir}/closure_compiler/compiler.jar
jsdoc-toolkit.dir = ${build.dir}/jsdoc-toolkit
-yuicompressor.jar = ${build.dir}/yuicompressor/yuicompressor-2.4.2.jar
jslint.jar = ${build.dir}/jslint4java/jslint4java-1.4.6.jar
+
product.name = signals
version.number = 0.6.3+
+
dist.name = ${product.name}.js
dist.min.name = ${product.name}.min.js
View
202 dev/build/closure_compiler/COPYING
@@ -0,0 +1,202 @@
+
+ Apache License
+ Version 2.0, January 2004
+ http://www.apache.org/licenses/
+
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+ 1. Definitions.
+
+ "License" shall mean the terms and conditions for use, reproduction,
+ and distribution as defined by Sections 1 through 9 of this document.
+
+ "Licensor" shall mean the copyright owner or entity authorized by
+ the copyright owner that is granting the License.
+
+ "Legal Entity" shall mean the union of the acting entity and all
+ other entities that control, are controlled by, or are under common
+ control with that entity. For the purposes of this definition,
+ "control" means (i) the power, direct or indirect, to cause the
+ direction or management of such entity, whether by contract or
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
+ outstanding shares, or (iii) beneficial ownership of such entity.
+
+ "You" (or "Your") shall mean an individual or Legal Entity
+ exercising permissions granted by this License.
+
+ "Source" form shall mean the preferred form for making modifications,
+ including but not limited to software source code, documentation
+ source, and configuration files.
+
+ "Object" form shall mean any form resulting from mechanical
+ transformation or translation of a Source form, including but
+ not limited to compiled object code, generated documentation,
+ and conversions to other media types.
+
+ "Work" shall mean the work of authorship, whether in Source or
+ Object form, made available under the License, as indicated by a
+ copyright notice that is included in or attached to the work
+ (an example is provided in the Appendix below).
+
+ "Derivative Works" shall mean any work, whether in Source or Object
+ form, that is based on (or derived from) the Work and for which the
+ editorial revisions, annotations, elaborations, or other modifications
+ represent, as a whole, an original work of authorship. For the purposes
+ of this License, Derivative Works shall not include works that remain
+ separable from, or merely link (or bind by name) to the interfaces of,
+ the Work and Derivative Works thereof.
+
+ "Contribution" shall mean any work of authorship, including
+ the original version of the Work and any modifications or additions
+ to that Work or Derivative Works thereof, that is intentionally
+ submitted to Licensor for inclusion in the Work by the copyright owner
+ or by an individual or Legal Entity authorized to submit on behalf of
+ the copyright owner. For the purposes of this definition, "submitted"
+ means any form of electronic, verbal, or written communication sent
+ to the Licensor or its representatives, including but not limited to
+ communication on electronic mailing lists, source code control systems,
+ and issue tracking systems that are managed by, or on behalf of, the
+ Licensor for the purpose of discussing and improving the Work, but
+ excluding communication that is conspicuously marked or otherwise
+ designated in writing by the copyright owner as "Not a Contribution."
+
+ "Contributor" shall mean Licensor and any individual or Legal Entity
+ on behalf of whom a Contribution has been received by Licensor and
+ subsequently incorporated within the Work.
+
+ 2. Grant of Copyright License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ copyright license to reproduce, prepare Derivative Works of,
+ publicly display, publicly perform, sublicense, and distribute the
+ Work and such Derivative Works in Source or Object form.
+
+ 3. Grant of Patent License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ (except as stated in this section) patent license to make, have made,
+ use, offer to sell, sell, import, and otherwise transfer the Work,
+ where such license applies only to those patent claims licensable
+ by such Contributor that are necessarily infringed by their
+ Contribution(s) alone or by combination of their Contribution(s)
+ with the Work to which such Contribution(s) was submitted. If You
+ institute patent litigation against any entity (including a
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
+ or a Contribution incorporated within the Work constitutes direct
+ or contributory patent infringement, then any patent licenses
+ granted to You under this License for that Work shall terminate
+ as of the date such litigation is filed.
+
+ 4. Redistribution. You may reproduce and distribute copies of the
+ Work or Derivative Works thereof in any medium, with or without
+ modifications, and in Source or Object form, provided that You
+ meet the following conditions:
+
+ (a) You must give any other recipients of the Work or
+ Derivative Works a copy of this License; and
+
+ (b) You must cause any modified files to carry prominent notices
+ stating that You changed the files; and
+
+ (c) You must retain, in the Source form of any Derivative Works
+ that You distribute, all copyright, patent, trademark, and
+ attribution notices from the Source form of the Work,
+ excluding those notices that do not pertain to any part of
+ the Derivative Works; and
+
+ (d) If the Work includes a "NOTICE" text file as part of its
+ distribution, then any Derivative Works that You distribute must
+ include a readable copy of the attribution notices contained
+ within such NOTICE file, excluding those notices that do not
+ pertain to any part of the Derivative Works, in at least one
+ of the following places: within a NOTICE text file distributed
+ as part of the Derivative Works; within the Source form or
+ documentation, if provided along with the Derivative Works; or,
+ within a display generated by the Derivative Works, if and
+ wherever such third-party notices normally appear. The contents
+ of the NOTICE file are for informational purposes only and
+ do not modify the License. You may add Your own attribution
+ notices within Derivative Works that You distribute, alongside
+ or as an addendum to the NOTICE text from the Work, provided
+ that such additional attribution notices cannot be construed
+ as modifying the License.
+
+ You may add Your own copyright statement to Your modifications and
+ may provide additional or different license terms and conditions
+ for use, reproduction, or distribution of Your modifications, or
+ for any such Derivative Works as a whole, provided Your use,
+ reproduction, and distribution of the Work otherwise complies with
+ the conditions stated in this License.
+
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
+ any Contribution intentionally submitted for inclusion in the Work
+ by You to the Licensor shall be under the terms and conditions of
+ this License, without any additional terms or conditions.
+ Notwithstanding the above, nothing herein shall supersede or modify
+ the terms of any separate license agreement you may have executed
+ with Licensor regarding such Contributions.
+
+ 6. Trademarks. This License does not grant permission to use the trade
+ names, trademarks, service marks, or product names of the Licensor,
+ except as required for reasonable and customary use in describing the
+ origin of the Work and reproducing the content of the NOTICE file.
+
+ 7. Disclaimer of Warranty. Unless required by applicable law or
+ agreed to in writing, Licensor provides the Work (and each
+ Contributor provides its Contributions) on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ implied, including, without limitation, any warranties or conditions
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+ PARTICULAR PURPOSE. You are solely responsible for determining the
+ appropriateness of using or redistributing the Work and assume any
+ risks associated with Your exercise of permissions under this License.
+
+ 8. Limitation of Liability. In no event and under no legal theory,
+ whether in tort (including negligence), contract, or otherwise,
+ unless required by applicable law (such as deliberate and grossly
+ negligent acts) or agreed to in writing, shall any Contributor be
+ liable to You for damages, including any direct, indirect, special,
+ incidental, or consequential damages of any character arising as a
+ result of this License or out of the use or inability to use the
+ Work (including but not limited to damages for loss of goodwill,
+ work stoppage, computer failure or malfunction, or any and all
+ other commercial damages or losses), even if such Contributor
+ has been advised of the possibility of such damages.
+
+ 9. Accepting Warranty or Additional Liability. While redistributing
+ the Work or Derivative Works thereof, You may choose to offer,
+ and charge a fee for, acceptance of support, warranty, indemnity,
+ or other liability obligations and/or rights consistent with this
+ License. However, in accepting such obligations, You may act only
+ on Your own behalf and on Your sole responsibility, not on behalf
+ of any other Contributor, and only if You agree to indemnify,
+ defend, and hold each Contributor harmless for any liability
+ incurred by, or claims asserted against, such Contributor by reason
+ of your accepting any such warranty or additional liability.
+
+ END OF TERMS AND CONDITIONS
+
+ APPENDIX: How to apply the Apache License to your work.
+
+ To apply the Apache License to your work, attach the following
+ boilerplate notice, with the fields enclosed by brackets "[]"
+ replaced with your own identifying information. (Don't include
+ the brackets!) The text should be enclosed in the appropriate
+ comment syntax for the file format. We also recommend that a
+ file or class name and description of purpose be included on the
+ same "printed page" as the copyright notice for easier
+ identification within third-party archives.
+
+ Copyright [yyyy] [name of copyright owner]
+
+ 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.
View
292 dev/build/closure_compiler/README
@@ -0,0 +1,292 @@
+/*
+ * Copyright 2009 The Closure Compiler Authors.
+ *
+ * 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.
+ */
+
+//
+// Contents
+//
+
+The Closure Compiler performs checking, instrumentation, and
+optimizations on JavaScript code. The purpose of this README is to
+explain how to build and run the Closure Compiler.
+
+The Closure Compiler requires Java 6 or higher.
+http://www.java.com/
+
+
+//
+// Building The Closure Compiler
+//
+
+There are three ways to get a Closure Compiler executable.
+
+1) Use one we built for you.
+
+Pre-built Closure binaries can be found at
+http://code.google.com/p/closure-compiler/downloads/list
+
+
+2) Check out the source and build it with Apache Ant.
+
+First, check out the full source tree of the Closure Compiler. There
+are instructions on how to do this at the project site.
+http://code.google.com/p/closure-compiler/source/checkout
+
+Apache Ant is a cross-platform build tool.
+http://ant.apache.org/
+
+At the root of the source tree, there is an Ant file named
+build.xml. To use it, navigate to the same directory and type the
+command
+
+ant jar
+
+This will produce a jar file called "build/compiler.jar".
+
+
+3) Check out the source and build it with Eclipse.
+
+Eclipse is a cross-platform IDE.
+http://www.eclipse.org/
+
+Under Eclipse's File menu, click "New > Project ..." and create a
+"Java Project." You will see an options screen. Give the project a
+name, select "Create project from existing source," and choose the
+root of the checked-out source tree as the existing directory. Verify
+that you are using JRE version 6 or higher.
+
+Eclipse can use the build.xml file to discover rules. When you
+navigate to the build.xml file, you will see all the build rules in
+the "Outline" pane. Run the "jar" rule to build the compiler in
+build/compiler.jar.
+
+
+//
+// Running The Closure Compiler
+//
+
+Once you have the jar binary, running the Closure Compiler is straightforward.
+
+On the command line, type
+
+java -jar compiler.jar
+
+This starts the compiler in interactive mode. Type
+
+var x = 17 + 25;
+
+then hit "Enter", then hit "Ctrl-Z" (on Windows) or "Ctrl-D" (on Mac or Linux)
+and "Enter" again. The Compiler will respond:
+
+var x=42;
+
+The Closure Compiler has many options for reading input from a file,
+writing output to a file, checking your code, and running
+optimizations. To learn more, type
+
+java -jar compiler.jar --help
+
+You can read more detailed documentation about the many flags at
+http://code.google.com/closure/compiler/docs/gettingstarted_app.html
+
+
+//
+// Compiling Multiple Scripts
+//
+
+If you have multiple scripts, you should compile them all together with
+one compile command.
+
+java -jar compiler.jar --js=in1.js --js=in2.js ... --js_output_file=out.js
+
+The Closure Compiler will concatenate the files in the order they're
+passed at the command line.
+
+If you need to compile many, many scripts together, you may start to
+run into problems with managing dependencies between scripts. You
+should check out the Closure Library. It contains functions for
+enforcing dependencies between scripts, and a tool called calcdeps.py
+that knows how to give scripts to the Closure Compiler in the right
+order.
+
+http://code.google.com/p/closure-library/
+
+//
+// Licensing
+//
+
+Unless otherwise stated, all source files are licensed under
+the Apache License, Version 2.0.
+
+
+-----
+Code under:
+src/com/google/javascript/rhino
+test/com/google/javascript/rhino
+
+URL: http://www.mozilla.org/rhino
+Version: 1.5R3, with heavy modifications
+License: Netscape Public License and MPL / GPL dual license
+
+Description: A partial copy of Mozilla Rhino. Mozilla Rhino is an
+implementation of JavaScript for the JVM. The JavaScript parser and
+the parse tree data structures were extracted and modified
+significantly for use by Google's JavaScript compiler.
+
+Local Modifications: The packages have been renamespaced. All code not
+relavant to parsing has been removed. A JSDoc parser and static typing
+system have been added.
+
+
+-----
+Code in:
+lib/rhino
+
+Rhino
+URL: http://www.mozilla.org/rhino
+Version: Trunk
+License: Netscape Public License and MPL / GPL dual license
+
+Description: Mozilla Rhino is an implementation of JavaScript for the JVM.
+
+Local Modifications: Minor changes to parsing JSDoc that usually get pushed
+up-stream to Rhino trunk.
+
+
+-----
+Code in:
+lib/args4j.jar
+
+Args4j
+URL: https://args4j.dev.java.net/
+Version: 2.0.12
+License: MIT
+
+Description:
+args4j is a small Java class library that makes it easy to parse command line
+options/arguments in your CUI application.
+
+Local Modifications: None.
+
+
+-----
+Code in:
+lib/guava.jar
+
+Guava Libraries
+URL: http://code.google.com/p/guava-libraries/
+Version: r08
+License: Apache License 2.0
+
+Description: Google's core Java libraries.
+
+Local Modifications: None.
+
+
+-----
+Code in:
+lib/jsr305.jar
+
+Annotations for software defect detection
+URL: http://code.google.com/p/jsr-305/
+Version: svn revision 47
+License: BSD License
+
+Description: Annotations for software defect detection.
+
+Local Modifications: None.
+
+
+-----
+Code in:
+lib/jarjar.jar
+
+Jar Jar Links
+URL: http://jarjar.googlecode.com/
+Version: 1.1
+License: Apache License 2.0
+
+Description:
+A utility for repackaging Java libraries.
+
+Local Modifications: None.
+
+
+----
+Code in:
+lib/junit.jar
+
+JUnit
+URL: http://sourceforge.net/projects/junit/
+Version: 4.8.2
+License: Common Public License 1.0
+
+Description: A framework for writing and running automated tests in Java.
+
+Local Modifications: None.
+
+
+---
+Code in:
+lib/protobuf-java.jar
+
+Protocol Buffers
+URL: http://code.google.com/p/protobuf/
+Version: 2.3.0
+License: New BSD License
+
+Description: Supporting libraries for protocol buffers,
+an encoding of structured data.
+
+Local Modifications: None
+
+
+---
+Code in:
+lib/ant.jar
+lib/ant-launcher.jar
+
+URL: http://ant.apache.org/bindownload.cgi
+Version: 1.8.1
+License: Apache License 2.0
+Description:
+ Ant is a Java based build tool. In theory it is kind of like "make"
+ without make's wrinkles and with the full portability of pure java code.
+
+Local Modifications: None
+
+
+---
+Code in:
+lib/json.jar
+URL: http://json.org/java/index.html
+Version: JSON version 20090211
+License: MIT license
+Description:
+JSON is a set of java files for use in transmitting data in JSON format.
+
+Local Modifications: None
+
+---
+Code in:
+tools/maven-ant-tasks-2.1.1.jar
+URL: http://maven.apache.org
+Version 2.1.1
+License: Apache License 2.0
+Description:
+ Maven Ant tasks are used to manage dependencies and to install/deploy to
+ maven repositories.
+
+Local Modifications: None
View
BIN  dev/build/closure_compiler/compiler.jar
Binary file not shown
View
2  dev/build/externs.js
@@ -0,0 +1,2 @@
+//CommonJS and AMD
+var exports, require, define, module;
View
140 dev/build/yuicompressor/README
@@ -1,140 +0,0 @@
-==============================================================================
-YUI Compressor
-==============================================================================
-
-NAME
-
- YUI Compressor - The Yahoo! JavaScript and CSS Compressor
-
-SYNOPSIS
-
- Usage: java -jar yuicompressor-x.y.z.jar [options] [input file]
-
- Global Options
- -h, --help Displays this information
- --type <js|css> Specifies the type of the input file
- --charset <charset> Read the input file using <charset>
- --line-break <column> Insert a line break after the specified column number
- -v, --verbose Display informational messages and warnings
- -o <file> Place the output into <file>. Defaults to stdout.
-
- JavaScript Options
- --nomunge Minify only, do not obfuscate
- --preserve-semi Preserve all semicolons
- --disable-optimizations Disable all micro optimizations
-
-DESCRIPTION
-
- The YUI Compressor is a JavaScript compressor which, in addition to removing
- comments and white-spaces, obfuscates local variables using the smallest
- possible variable name. This obfuscation is safe, even when using constructs
- such as 'eval' or 'with' (although the compression is not optimal is those
- cases) Compared to jsmin, the average savings is around 20%.
-
- The YUI Compressor is also able to safely compress CSS files. The decision
- on which compressor is being used is made on the file extension (js or css)
-
-GLOBAL OPTIONS
-
- -h, --help
- Prints help on how to use the YUI Compressor
-
- --line-break
- Some source control tools don't like files containing lines longer than,
- say 8000 characters. The linebreak option is used in that case to split
- long lines after a specific column. It can also be used to make the code
- more readable, easier to debug (especially with the MS Script Debugger)
- Specify 0 to get a line break after each semi-colon in JavaScript, and
- after each rule in CSS.
-
- --type js|css
- The type of compressor (JavaScript or CSS) is chosen based on the
- extension of the input file name (.js or .css) This option is required
- if no input file has been specified. Otherwise, this option is only
- required if the input file extension is neither 'js' nor 'css'.
-
- --charset character-set
- If a supported character set is specified, the YUI Compressor will use it
- to read the input file. Otherwise, it will assume that the platform's
- default character set is being used. The output file is encoded using
- the same character set.
-
- -o outfile
- Place output in file outfile. If not specified, the YUI Compressor will
- default to the standard output, which you can redirect to a file.
-
- -v, --verbose
- Display informational messages and warnings.
-
-JAVASCRIPT ONLY OPTIONS
-
- --nomunge
- Minify only. Do not obfuscate local symbols.
-
- --preserve-semi
- Preserve unnecessary semicolons (such as right before a '}') This option
- is useful when compressed code has to be run through JSLint (which is the
- case of YUI for example)
-
- --disable-optimizations
- Disable all the built-in micro optimizations.
-
-NOTES
-
- + If no input file is specified, it defaults to stdin.
-
- + The YUI Compressor requires Java version >= 1.4.
-
- + It is possible to prevent a local variable, nested function or function
- argument from being obfuscated by using "hints". A hint is a string that
- is located at the very beginning of a function body like so:
-
- function fn (arg1, arg2, arg3) {
- "arg2:nomunge, localVar:nomunge, nestedFn:nomunge";
-
- ...
- var localVar;
- ...
-
- function nestedFn () {
- ....
- }
-
- ...
- }
-
- The hint itself disappears from the compressed file.
-
- + C-style comments starting with /*! are preserved. This is useful with
- comments containing copyright/license information. For example:
-
- /*!
- * TERMS OF USE - EASING EQUATIONS
- * Open source under the BSD License.
- * Copyright 2001 Robert Penner All rights reserved.
- */
-
- becomes:
-
- /*
- * TERMS OF USE - EASING EQUATIONS
- * Open source under the BSD License.
- * Copyright 2001 Robert Penner All rights reserved.
- */
-
-AUTHOR
-
- The YUI Compressor was written and is maintained by:
- Julien Lecomte <jlecomte@yahoo-inc.com>
- The CSS portion is a port of Isaac Schlueter's cssmin utility.
-
-COPYRIGHT
-
- Copyright (c) 2007-2009, Yahoo! Inc. All rights reserved.
-
-LICENSE
-
- All code specific to YUI Compressor is issued under a BSD license.
- YUI Compressor extends and implements code from Mozilla's Rhino project.
- Rhino is issued under the Mozilla Public License (MPL), and MPL applies
- to the Rhino source and binaries that are distributed with YUI Compressor.
View
BIN  dev/build/yuicompressor/yuicompressor-2.4.2.jar
Binary file not shown
View
11 dev/src/license.txt
@@ -1,7 +1,6 @@
-/*!!
+/** @license
* JS Signals <http://millermedeiros.github.com/js-signals/>
- * Released under the MIT license <http://www.opensource.org/licenses/mit-license.php>
- * @author Miller Medeiros <http://millermedeiros.com/>
- * @version ::VERSION_NUMBER::
- * @build ::BUILD_NUMBER:: (::BUILD_DATE::)
- */
+ * Released under the MIT license
+ * Author: Miller Medeiros
+ * Version: ::VERSION_NUMBER:: - Build: ::BUILD_NUMBER:: (::BUILD_DATE::)
+ */
View
10 dist/signals.js
@@ -1,13 +1,13 @@
/*jslint onevar:true, undef:true, newcap:true, regexp:true, bitwise:true, maxerr:50, indent:4, white:false, nomen:false, plusplus:false */
/*global define:false, require:false, exports:false, module:false*/
-/*!!
+/** @license
* JS Signals <http://millermedeiros.github.com/js-signals/>
- * Released under the MIT license <http://www.opensource.org/licenses/mit-license.php>
- * @author Miller Medeiros <http://millermedeiros.com/>
- * @version 0.6.3+
- * @build 227 (2011/10/28 11:59 AM)
+ * Released under the MIT license
+ * Author: Miller Medeiros
+ * Version: 0.6.3+ - Build: 234 (2011/10/28 12:21 PM)
*/
+
(function(global){
/**
View
24 dist/signals.min.js
@@ -1,8 +1,16 @@
-/*!
- * JS Signals <http://millermedeiros.github.com/js-signals/>
- * Released under the MIT license <http://www.opensource.org/licenses/mit-license.php>
- * @author Miller Medeiros <http://millermedeiros.com/>
- * @version 0.6.3+
- * @build 227 (2011/10/28 11:59 AM)
- */
-(function(d){var b={VERSION:"0.6.3+"};function c(i,h,f,g,e){this._listener=h;this._isOnce=f;this.context=g;this._signal=i;this._priority=e||0}c.prototype={active:true,params:null,execute:function(e){var g,f;if(this.active&&!!this._listener){f=this.params?this.params.concat(e):e;g=this._listener.apply(this.context,f);if(this._isOnce){this.detach()}}return g},detach:function(){return this.isBound()?this._signal.remove(this._listener):null},isBound:function(){return(!!this._signal&&!!this._listener)},getListener:function(){return this._listener},_destroy:function(){delete this._signal;delete this._listener;delete this.context},isOnce:function(){return this._isOnce},toString:function(){return"[SignalBinding isOnce:"+this._isOnce+", isBound:"+this.isBound()+", active:"+this.active+"]"}};function a(e,f){if(typeof e!=="function"){throw new Error("listener is a required param of {fn}() and should be a Function.".replace("{fn}",f))}}b.Signal=function(){this._bindings=[];this._prevParams=null};b.Signal.prototype={memorize:false,_shouldPropagate:true,active:true,_registerListener:function(i,h,g,f){var e=this._indexOfListener(i),j;if(e!==-1){j=this._bindings[e];if(j.isOnce()!==h){throw new Error("You cannot add"+(h?"":"Once")+"() then add"+(!h?"":"Once")+"() the same listener without removing the relationship first.")}}else{j=new c(this,i,h,g,f);this._addBinding(j)}if(this.memorize&&this._prevParams){j.execute(this._prevParams)}return j},_addBinding:function(e){var f=this._bindings.length;do{--f}while(this._bindings[f]&&e._priority<=this._bindings[f]._priority);this._bindings.splice(f+1,0,e)},_indexOfListener:function(e){var f=this._bindings.length;while(f--){if(this._bindings[f]._listener===e){return f}}return -1},has:function(e){return this._indexOfListener(e)!==-1},add:function(g,f,e){a(g,"add");return this._registerListener(g,false,f,e)},addOnce:function(g,f,e){a(g,"addOnce");return this._registerListener(g,true,f,e)},remove:function(f){a(f,"remove");var e=this._indexOfListener(f);if(e!==-1){this._bindings[e]._destroy();this._bindings.splice(e,1)}return f},removeAll:function(){var e=this._bindings.length;while(e--){this._bindings[e]._destroy()}this._bindings.length=0},getNumListeners:function(){return this._bindings.length},halt:function(){this._shouldPropagate=false},dispatch:function(f){if(!this.active){return}var e=Array.prototype.slice.call(arguments),h=this._bindings.slice(),g=h.length;if(this.memorize){this._prevParams=e}this._shouldPropagate=true;do{g--}while(h[g]&&this._shouldPropagate&&h[g].execute(e)!==false)},forget:function(){this._prevParams=null},dispose:function(){this.removeAll();delete this._bindings;delete this._prevParams},toString:function(){return"[Signal active:"+this.active+" numListeners:"+this.getNumListeners()+"]"}};(function(){var f=b.Signal.prototype,h=new b.Signal();function g(i,j){return Array.prototype.slice.call(i,j||0)}function e(k){b.Signal.call(this);var i=g(arguments),l=i.length,j;while(l--){j=i[l].add(this._registerDispatch,this);j.params=[l]}this._signals=i;this._params=[];this._resolved=false}e.prototype=h;e.prototype.constructor=e;h.override=false;h.unique=true;h.memorize=true;h._registerDispatch=function(i,j){if(!this._params[i]||this.override){this._params[i]=g(arguments,1)}if(this._registeredAll()&&(!this._resolved||!this.unique)){this.dispatch.apply(this,this._params)}};h._registeredAll=function(){if(this._params.length!==this._signals.length){return false}else{for(var j=0,k=this._params.length;j<k;j+=1){if(!this._params[j]){return false}}return true}};h.dispatch=function(i){i=(this._resolved&&this.unique)?this._params:g(arguments);this._resolved=true;f.dispatch.apply(this,i);if(this.unique){this.removeAll()}else{this.reset()}};h.reset=function(){this._params.length=0;this._resolved=false};h.isResolved=function(){return this._resolved};h.dispose=function(){f.dispose.call(this);delete this._signals;delete this._params};h.toString=function(){return"[CompoundSignal active:"+this.active+" numListeners:"+this.getNumListeners()+"]"};b.CompoundSignal=e}());if(typeof define==="function"&&define.amd){define("signals",[],b)}else{if(typeof module!=="undefined"&&module.exports){module.exports=b}else{d.signals=b}}}(this));
+/*
+
+ JS Signals <http://millermedeiros.github.com/js-signals/>
+ Released under the MIT license
+ Author: Miller Medeiros
+ Version: 0.6.3+ - Build: 234 (2011/10/28 12:21 PM)
+*/
+(function(i){function h(a,b,c,e,g){this._listener=b;this._isOnce=c;this.context=e;this._signal=a;this._priority=g||0}function f(a,b){if(typeof a!=="function")throw Error("listener is a required param of {fn}() and should be a Function.".replace("{fn}",b));}var d={VERSION:"0.6.3+"};h.prototype={active:!0,params:null,execute:function(a){var b;this.active&&this._listener&&(a=this.params?this.params.concat(a):a,b=this._listener.apply(this.context,a),this._isOnce&&this.detach());return b},detach:function(){return this.isBound()?
+this._signal.remove(this._listener):null},isBound:function(){return!!this._signal&&!!this._listener},getListener:function(){return this._listener},_destroy:function(){delete this._signal;delete this._listener;delete this.context},isOnce:function(){return this._isOnce},toString:function(){return"[SignalBinding isOnce:"+this._isOnce+", isBound:"+this.isBound()+", active:"+this.active+"]"}};d.Signal=function(){this._bindings=[];this._prevParams=null};d.Signal.prototype={memorize:!1,_shouldPropagate:!0,
+active:!0,_registerListener:function(a,b,c,e){var g=this._indexOfListener(a);if(g!==-1){if(a=this._bindings[g],a.isOnce()!==b)throw Error("You cannot add"+(b?"":"Once")+"() then add"+(!b?"":"Once")+"() the same listener without removing the relationship first.");}else a=new h(this,a,b,c,e),this._addBinding(a);this.memorize&&this._prevParams&&a.execute(this._prevParams);return a},_addBinding:function(a){var b=this._bindings.length;do--b;while(this._bindings[b]&&a._priority<=this._bindings[b]._priority);
+this._bindings.splice(b+1,0,a)},_indexOfListener:function(a){for(var b=this._bindings.length;b--;)if(this._bindings[b]._listener===a)return b;return-1},has:function(a){return this._indexOfListener(a)!==-1},add:function(a,b,c){f(a,"add");return this._registerListener(a,!1,b,c)},addOnce:function(a,b,c){f(a,"addOnce");return this._registerListener(a,!0,b,c)},remove:function(a){f(a,"remove");var b=this._indexOfListener(a);b!==-1&&(this._bindings[b]._destroy(),this._bindings.splice(b,1));return a},removeAll:function(){for(var a=
+this._bindings.length;a--;)this._bindings[a]._destroy();this._bindings.length=0},getNumListeners:function(){return this._bindings.length},halt:function(){this._shouldPropagate=!1},dispatch:function(a){if(this.active){var b=Array.prototype.slice.call(arguments),c=this._bindings.slice(),e=c.length;if(this.memorize)this._prevParams=b;this._shouldPropagate=!0;do e--;while(c[e]&&this._shouldPropagate&&c[e].execute(b)!==!1)}},forget:function(){this._prevParams=null},dispose:function(){this.removeAll();
+delete this._bindings;delete this._prevParams},toString:function(){return"[Signal active:"+this.active+" numListeners:"+this.getNumListeners()+"]"}};(function(){function a(a){d.Signal.call(this);for(var b=Array.prototype.slice.call(arguments,0),c=b.length,f;c--;)f=b[c].add(this._registerDispatch,this),f.params=[c];this._signals=b;this._params=[];this._resolved=!1}var b=d.Signal.prototype,c=new d.Signal;a.prototype=c;a.prototype.constructor=a;c.override=!1;c.unique=!0;c.memorize=!0;c._registerDispatch=
+function(a,b){if(!this._params[a]||this.override)this._params[a]=Array.prototype.slice.call(arguments,1);this._registeredAll()&&(!this._resolved||!this.unique)&&this.dispatch.apply(this,this._params)};c._registeredAll=function(){if(this._params.length!==this._signals.length)return!1;else{for(var a=0,b=this._params.length;a<b;a+=1)if(!this._params[a])return!1;return!0}};c.dispatch=function(a){a=this._resolved&&this.unique?this._params:Array.prototype.slice.call(arguments,0);this._resolved=!0;b.dispatch.apply(this,
+a);this.unique?this.removeAll():this.reset()};c.reset=function(){this._params.length=0;this._resolved=!1};c.isResolved=function(){return this._resolved};c.dispose=function(){b.dispose.call(this);delete this._signals;delete this._params};c.toString=function(){return"[CompoundSignal active:"+this.active+" numListeners:"+this.getNumListeners()+"]"};d.CompoundSignal=a})();typeof define==="function"&&define.amd?define("signals",[],d):typeof module!=="undefined"&&module.exports?module.exports=d:i.signals=
+d})(this);
Please sign in to comment.
Something went wrong with that request. Please try again.