Initial commit

This commit is contained in:
github-classroom[bot] 2023-04-25 11:33:41 +00:00 committed by GitHub
commit e42e547e48
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1287 changed files with 553558 additions and 0 deletions

129
.gitignore vendored Normal file
View File

@ -0,0 +1,129 @@
# Byte-compiled / optimized / DLL files
__pycache__/
*.py[cod]
*$py.class
# C extensions
*.so
# Distribution / packaging
.Python
build/
develop-eggs/
dist/
downloads/
eggs/
.eggs/
lib/
lib64/
parts/
sdist/
var/
wheels/
pip-wheel-metadata/
share/python-wheels/
*.egg-info/
.installed.cfg
*.egg
MANIFEST
# PyInstaller
# Usually these files are written by a python script from a template
# before PyInstaller builds the exe, so as to inject date/other infos into it.
*.manifest
*.spec
# Installer logs
pip-log.txt
pip-delete-this-directory.txt
# Unit test / coverage reports
htmlcov/
.tox/
.nox/
.coverage
.coverage.*
.cache
nosetests.xml
coverage.xml
*.cover
*.py,cover
.hypothesis/
.pytest_cache/
# Translations
*.mo
*.pot
# Django stuff:
*.log
local_settings.py
db.sqlite3
db.sqlite3-journal
# Flask stuff:
instance/
.webassets-cache
# Scrapy stuff:
.scrapy
# Sphinx documentation
docs/_build/
# PyBuilder
target/
# Jupyter Notebook
.ipynb_checkpoints
# IPython
profile_default/
ipython_config.py
# pyenv
.python-version
# pipenv
# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control.
# However, in case of collaboration, if having platform-specific dependencies or dependencies
# having no cross-platform support, pipenv may install dependencies that don't work, or not
# install all needed dependencies.
#Pipfile.lock
# PEP 582; used by e.g. github.com/David-OConnor/pyflow
__pypackages__/
# Celery stuff
celerybeat-schedule
celerybeat.pid
# SageMath parsed files
*.sage.py
# Environments
.env
.venv
env/
venv/
ENV/
env.bak/
venv.bak/
# Spyder project settings
.spyderproject
.spyproject
# Rope project settings
.ropeproject
# mkdocs documentation
/site
# mypy
.mypy_cache/
.dmypy.json
dmypy.json
# Pyre type checker
.pyre/

10
README.md Normal file
View File

@ -0,0 +1,10 @@
# Information Modelling & Analysis: Project 2
Student: enter your name here
Please follow the instructions provided in the project slides
and consider the submission instructions available on iCorsi.
For your convencience, I the following resources are available in the `resources` folder:
- **defects4j-checkout-closure-1f**: The output of the command `defects4j checkout -p Closure -v 1f -w ...`
- **modified_classes** The list of buggy classes in: `framework/projects/Closure/modified_classes/`

0
evaluate_classifiers.py Normal file
View File

View File

0
label_feature_vectors.py Normal file
View File

View File

@ -0,0 +1,27 @@
<?xml version="1.0" encoding="UTF-8"?>
<classpath>
<classpathentry including="**/*.java" kind="src" output="build/test-classes" path="test"/>
<classpathentry including="**/*.java" kind="src" path="src"/>
<classpathentry including="**/*.java" kind="src" path="gen"/>
<classpathentry kind="lib" path="lib/ant.jar"/>
<classpathentry kind="lib" path="lib/ant-launcher.jar"/>
<classpathentry kind="lib" path="lib/args4j.jar"/>
<classpathentry kind="lib" path="lib/guava.jar"/>
<classpathentry kind="lib" path="lib/jarjar.jar"/>
<classpathentry kind="lib" path="lib/json.jar"/>
<classpathentry kind="lib" path="lib/jsr305.jar"/>
<classpathentry kind="lib" path="lib/junit.jar"/>
<classpathentry kind="lib" path="lib/caja-r4314.jar"/>
<classpathentry kind="lib" path="lib/protobuf-java.jar"/>
<!--
You need to tell Eclipse to build the compiler jar first, and then
normal source warnings will work because it will pick up the artifact.
If anyone has any better ideas, I'd be glad to hear them.
-->
<classpathentry kind="lib" path="build/lib/rhino.jar"/>
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
<classpathentry kind="output" path="build/classes"/>
</classpath>

View File

@ -0,0 +1,3 @@
#File automatically generated by Defects4J
pid=Closure
vid=1f

View File

@ -0,0 +1 @@
.svn

View File

@ -0,0 +1,17 @@
<?xml version="1.0" encoding="UTF-8"?>
<projectDescription>
<name>closure-compiler</name>
<comment></comment>
<projects>
</projects>
<buildSpec>
<buildCommand>
<name>org.eclipse.jdt.core.javabuilder</name>
<arguments>
</arguments>
</buildCommand>
</buildSpec>
<natures>
<nature>org.eclipse.jdt.core.javanature</nature>
</natures>
</projectDescription>

View File

@ -0,0 +1,61 @@
All contributors to Closure Compiler must sign a CLA.
What is a CLA?
----------------------------------------
A CLA (Contributor License Agreement) basically says that you own the
rights to any code you contribute, and that you give us permission to
use that code in Closure Compiler. You maintain the copyright on that
code.
Where do I sign up?
----------------------------------------
If you own all the rights to your code, you can fill out an individual CLA.
http://code.google.com/legal/individual-cla-v1.0.html
If your employer has any rights to your code, then they also need to fill
out a corporate CLA. If you don't know if your employer has any rights
to your code, you should ask before signing anything.
http://code.google.com/legal/corporate-cla-v1.0.html
CLA Signers
----------------------------------------
By default, anyone with an @google.com email address already has a CLA
signed for them. Congratulations!
We've also received CLAs from the following people:
amattie [gmail.com] (Andrew Mattie)
ambar.lee [gmail.com]
benjamin.j.mccann [gmail.com]
cpeisert [gmail.com] (Christopher Peisert)
chadkillingsworth [missouristate.edu] (Chad Killingsworth)
dunbarb2 [gmail.com]
edo999 [gmail.com]
franck.routier [gmail.com] (Franck Routier)
guido.tapia [gmail.com] (Guido Tapia)
ichaehoi [gmail.com] (Ibrahim Chaehoi)
iliakan [gmail.com] (Ilya Kantor)
ivan.kozik [gmail.com]
jaffathecake [gmail.com] (Jake Archibald)
jamesots [gmail.com]
jhansche [myyearbook.com] (Joe Hansche)
k [ailis.de] (Klaus Reimer)
kosmo.zb [gmail.com]
leeight [gmail.com]
mattcg [gmail.com]
meacer [gmail.com] (Mustafa E. Acer)
mbolin [gmail.com] (Michael Bolin)
neaket [gmail.com]
piaohai [gmail.com] (piaohaiyao)
pimmhogeling [gmail.com]
price.c [gmail.com] (Chris Price)
rictic [gmail.com] (Peter Burns)
robert [gust-bardon.org] (Robert Gust-Bardon)
sheets [ashimaarts.com]
stenrs [gmail.com]
timwintle [gmail.com] (Tim Wintle)
yonathan [gmail.com] (Yonathan Randolph)

View File

@ -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 File

@ -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
relevant 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.16
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: 13.0.1
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.10
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.4.1
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.3.jar
URL: http://maven.apache.org
Version 2.1.3
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 File

@ -0,0 +1,505 @@
<!--
Copyright 2009 Google Inc.
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.
-->
<project name="compiler" basedir="." default="jar" xmlns:artifact="antlib:org.apache.maven.artifact.ant">
<!--
Use -Dtest.class to change what tests are run on the command-line.
i.e., -Dtest.class=CommandLineRunnerTest will run just that test class.
-->
<property name="test.class" value="*Test"/>
<!--
Use -Dtest.fork to specify whether or not to fork the process.
Some machines run better with forking turned off.
-->
<property name="test.fork" value="true"/>
<!-- Force java 6 -->
<property name="ant.build.javac.source" value="1.6" />
<property name="ant.build.javac.target" value="1.6" />
<!-- define other variables -->
<property name="javac.debug" value="on" />
<property name="src.dir" value="${basedir}/src" />
<property name="gen.dir" value="${basedir}/gen" />
<property name="test.dir" value="${basedir}/test" />
<property name="externs.dir" value="${basedir}/externs" />
<!-- To workaround Ant limitation on overriding properties set on the
command-line, define a unique property to allow "build.dir" to
be change without forcing the build of Rhino to the same directory.
-->
<property name="closure.build.dir" value="${basedir}/build" />
<property name="build.dir" value="${closure.build.dir}" />
<property name="buildlib.dir" value="${build.dir}/lib" />
<property name="classes.dir" value="${build.dir}/classes" />
<property name="testClasses.dir" value="${build.dir}/test" />
<property name="javadoc.dir" value="${build.dir}/javadoc" />
<property name="stylesheetfile" value="${javadoc.dir}/dev_javadoc.css" />
<property name="lib.dir" value="${basedir}/lib" />
<property name="tools.dir" value="${basedir}/tools" />
<property name="compiler-jarfile"
value="${build.dir}/${ant.project.name}.jar" />
<property name="num-fuzz-tests" value="10000"/>
<property name="jsonml.dir" value="${basedir}/src/com/google/javascript/jscomp/jsonml" />
<property name="jsonml-classes.dir" value = "${build.dir}/jsonml-classes" />
<property name="jsonml-jarfile" value="${build.dir}/secure_compiler.jar" />
<property name="webservice.dir" value="${basedir}/src/com/google/javascript/jscomp/webservice" />
<property name="webservice-classes.dir" value = "${build.dir}/webservice-classes" />
<property name="webservice-jarfile" value="${build.dir}/webservice.jar" />
<!-- The following server is used to deploy releases to maven central via Sonatypes
publishing service which runs on oss.sonatype.org.
You will need to have an account on sonatype.org to push releases. You can
override these values if you want to deploy to a different repository
-->
<property name="maven-repository-url" value="https://oss.sonatype.org/service/local/staging/deploy/maven2/" />
<property name="maven-repository-id" value="sonatype-nexus-staging" />
<!-- proto compiler used to generate java classes from .proto files -->
<property name="protoc.executable" value="protoc"/>
<property file="build.properties" />
<!-- maven ant tasks -->
<path id="maven-ant-tasks.classpath" path="${tools.dir}/maven-ant-tasks-2.1.3.jar" />
<typedef resource="org/apache/maven/artifact/ant/antlib.xml"
uri="antlib:org.apache.maven.artifact.ant"
classpathref="maven-ant-tasks.classpath" />
<!-- gather svn version -->
<target name="svnversion">
<exec outputproperty="build.svnVersion"
executable="svnversion"
failonerror="false"
failifexecutionfails="false"
dir="."/>
</target>
<!-- compile rhino -->
<target name="rhino">
<ant antfile="build.xml"
inheritAll="false"
dir="lib/rhino/"
target="jar">
<property name="build.dir" value="${buildlib.dir}"/>
<property name="no-e4x" value="true"/>
</ant>
</target>
<target name="rhino-jarjar"
depends="rhino"
description="Renamespaces Rhino">
<taskdef name="jarjar"
classname="com.tonicsystems.jarjar.JarJarTask"
classpath="lib/jarjar.jar"/>
<jarjar destfile="${buildlib.dir}/rhino.jar" update="true">
<zipfileset src="${buildlib.dir}/rhino1_7R5pre/js.jar"/>
<rule pattern="org.mozilla.javascript.**"
result="com.google.javascript.rhino.head.@1"/>
</jarjar>
</target>
<target name="protobuf-gen">
<fileset dir="${src.dir}" id="proto.classpath">
<include name="**/*.proto"/>
</fileset>
<pathconvert property="protofiles" pathsep=" " refid="proto.classpath"/>
<echo message="${protoc.executable} -I ${src.dir} --java_out=${gen.dir} ${protofiles}"/>
<exec executable="${protoc.executable}" searchpath="true">
<arg line="-I ${src.dir}"/>
<arg line="--java_out=${gen.dir}"/>
<arg line="${protofiles}"/>
</exec>
</target>
<!-- Generate pom.xml with the proper svn build number -->
<target name="pom" depends="svnversion">
<copy file="closure-compiler.pom" tofile="${build.dir}/pom.xml">
<filterset>
<filter token="build.svnVersion"
value="${build.svnVersion}"/>
</filterset>
</copy>
<property name="compiler-jarfile-nodeps" value="${build.dir}/closure-${ant.project.name}-r${build.svnVersion}.jar" />
<property name="compiler-jarfile-javadoc" value="${build.dir}/closure-${ant.project.name}-r${build.svnVersion}-javadoc.jar" />
<property name="compiler-jarfile-sources" value="${build.dir}/closure-${ant.project.name}-r${build.svnVersion}-sources.jar" />
<artifact:pom id="project" file="${build.dir}/pom.xml" />
</target>
<target name="mvn-install"
depends="jar-nodeps,jar-javadoc,jar-sources,pom"
description="Install closure-compiler artifacts into the local maven repo">
<artifact:install file="${compiler-jarfile-nodeps}">
<pom refid="project"/>
<attach file="${compiler-jarfile-javadoc}" classifier="javadoc"/>
<attach file="${compiler-jarfile-sources}" classifier="sources"/>
</artifact:install>
</target>
<!-- The mvn-deploy target takes the generated maven artifacts and pushes
them to the Sonatype repository. You will need to have a
gpg key defined and account set up. More docs on how to do this here:
https://docs.sonatype.org/display/Repository/Sonatype+OSS+Maven+Repository+Usage+Guide
-->
<target name="mvn-deploy"
depends="mvn-install"
description="Signs and Deploys closure-compiler artifacts to the central maven repo">
<!-- sign and deploy the main artifact -->
<artifact:mvn>
<arg value="org.apache.maven.plugins:maven-gpg-plugin:1.1:sign-and-deploy-file" />
<arg value="-Durl=${maven-repository-url}" />
<arg value="-DrepositoryId=${maven-repository-id}" />
<arg value="-DpomFile=${build.dir}/pom.xml" />
<arg value="-Dfile=${compiler-jarfile-nodeps}" />
<arg value="-Pgpg" />
</artifact:mvn>
<!-- sign and deploy the sources artifact -->
<artifact:mvn>
<arg value="org.apache.maven.plugins:maven-gpg-plugin:1.1:sign-and-deploy-file" />
<arg value="-Durl=${maven-repository-url}" />
<arg value="-DrepositoryId=${maven-repository-id}" />
<arg value="-DpomFile=${build.dir}/pom.xml" />
<arg value="-Dfile=${compiler-jarfile-sources}" />
<arg value="-Dclassifier=sources" />
<arg value="-Pgpg" />
</artifact:mvn>
<!-- sign and deploy the javadoc artifact -->
<artifact:mvn>
<arg value="org.apache.maven.plugins:maven-gpg-plugin:1.1:sign-and-deploy-file" />
<arg value="-Durl=${maven-repository-url}" />
<arg value="-DrepositoryId=${maven-repository-id}" />
<arg value="-DpomFile=${build.dir}/pom.xml" />
<arg value="-Dfile=${compiler-jarfile-javadoc}" />
<arg value="-Dclassifier=javadoc" />
<arg value="-Pgpg" />
</artifact:mvn>
</target>
<!-- Sync maven dependencies listed in pom.xml -->
<target name="mvn-deps-sync" description="sync dependencies/jars in closure-compiler.pom to lib" depends="pom">
<artifact:dependencies filesetid="dependency.fileset"
pathid="dependency.classpath"
pomrefid="project"
versionsId="dependency.versions"/>
<mkdir dir="${lib.dir}"/>
<copy todir="${lib.dir}">
<fileset refid="dependency.fileset" />
<!-- This mapper strips off all leading directory information -->
<mapper classpathref="maven-ant-tasks.classpath"
classname="org.apache.maven.artifact.ant.VersionMapper"
from="${dependency.versions}" to="flatten" />
</copy>
</target>
<!-- set the classpath for the project -->
<!-- this includes the generated source class files -->
<!-- and every jar in the /lib directory -->
<path id="srcclasspath.path">
<pathelement location="${classes.dir}" />
<fileset dir="${lib.dir}">
<include name="args4j.jar"/>
<include name="guava.jar"/>
<include name="json.jar"/>
<include name="jsr305.jar"/>
<include name="protobuf-java.jar"/>
</fileset>
<fileset dir="${buildlib.dir}">
<include name="rhino.jar"/>
</fileset>
</path>
<path id="allclasspath.path">
<pathelement location="${classes.dir}" />
<fileset dir="${lib.dir}">
<include name="*.jar"/>
</fileset>
<fileset dir="${buildlib.dir}">
<include name="rhino.jar"/>
</fileset>
</path>
<target name="clean" description="delete generated files">
<delete dir="${build.dir}" />
</target>
<target name="compile"
description="compile the source code"
depends="rhino-jarjar,svnversion">
<mkdir dir="${classes.dir}" />
<javac debug="true" srcdir="${gen.dir}"
destdir="${classes.dir}"
excludes=".svn"
>
<classpath refid="srcclasspath.path" />
</javac>
<javac debug="true" srcdir="${src.dir}"
destdir="${classes.dir}"
excludes=".svn,**/jsonml/**,**/webservice/**,**/testing/**"
>
<classpath refid="srcclasspath.path" />
</javac>
<!-- Move Messages.properties where ScriptRuntime.java expects it. -->
<mkdir dir="${classes.dir}/rhino_ast/java/com/google/javascript/rhino/" />
<copy file="${src.dir}/com/google/javascript/rhino/Messages.properties"
todir="${classes.dir}/rhino_ast/java/com/google/javascript/rhino/" />
<!-- Move ParserConfig.properties where ParserRunner.java expects it. -->
<copy file="${src.dir}/com/google/javascript/jscomp/parsing/ParserConfig.properties"
todir="${classes.dir}/com/google/javascript/jscomp/parsing" />
<propertyfile
file="${classes.dir}/com/google/javascript/jscomp/parsing/ParserConfig.properties"
comment="Parser properties">
<entry key="compiler.date" type="date" value="now"/>
<entry key="compiler.version" value="${build.svnVersion}"/>
</propertyfile>
<!-- Move runtime_type_check.js where RuntimeTypeCheck.java expects it. -->
<mkdir dir="${classes.dir}/com/google/javascript/jscomp/js" />
<copy todir="${classes.dir}/com/google/javascript/jscomp/js">
<fileset dir="${src.dir}/com/google/javascript/jscomp/js" />
</copy>
</target>
<target name="jar-nodeps"
depends="compile,pom"
description="package compiler as an executable jar">
<zip destfile="${build.dir}/externs.zip" basedir="${externs.dir}" />
<jar destfile="${compiler-jarfile-nodeps}" update="true">
<fileset dir="${classes.dir}" />
<fileset dir="${build.dir}" includes="externs.zip" />
<zipfileset src="${build.dir}/lib/rhino.jar"/>
</jar>
</target>
<target name="jar"
depends="compile"
description="package compiler as an executable jar">
<zip destfile="${build.dir}/externs.zip" basedir="${externs.dir}" includes="*.js" />
<jar destfile="${compiler-jarfile}" update="true">
<fileset dir="${classes.dir}" />
<fileset dir="${build.dir}" includes="externs.zip" />
<zipfileset src="${lib.dir}/args4j.jar"/>
<zipfileset src="${lib.dir}/guava.jar"/>
<zipfileset src="${lib.dir}/json.jar"/>
<zipfileset src="${lib.dir}/jsr305.jar"/>
<zipfileset src="${lib.dir}/protobuf-java.jar"/>
<zipfileset src="${buildlib.dir}/rhino.jar"/>
<manifest>
<attribute name="Main-Class"
value="com.google.javascript.jscomp.CommandLineRunner" />
</manifest>
</jar>
</target>
<target name="compile-tests"
depends="compile"
description="compile the JUnit tests">
<mkdir dir="${testClasses.dir}" />
<javac debug="true" srcdir="${src.dir}"
destdir="${testClasses.dir}"
excludes=".svn"
>
<classpath refid="allclasspath.path" />
</javac>
<javac debug="true" srcdir="${test.dir}"
destdir="${testClasses.dir}"
excludes=".svn"
>
<classpath refid="allclasspath.path" />
</javac>
</target>
<target name="all-classes-jar"
depends="compile,compile-tests"
description="package the compiler and its tests into one jar">
<jar destfile="${compiler-jarfile}" update="true">
<fileset dir="${testClasses.dir}" />
<zipgroupfileset dir="${lib.dir}" includes="*.jar"/>
<zipfileset src="${buildlib.dir}/rhino.jar"/>
</jar>
</target>
<target name="test"
depends="compile-tests"
description="Compile and execute the JUnit tests.">
<mkdir dir="build/testoutput"/>
<junit printsummary="on" fork="${test.fork}"
forkmode="once" showoutput="true"
failureproperty="junit.failure">
<classpath refid="allclasspath.path" />
<classpath>
<pathelement location="${build.dir}/test" />
</classpath>
<batchtest todir="build/testoutput">
<formatter type="brief" usefile="false" />
<formatter type="xml" />
<fileset dir="${build.dir}/test">
<include name="**/${test.class}.class" />
</fileset>
</batchtest>
</junit>
<junitreport>
<fileset dir="build/testoutput" includes="*.xml"/>
<report todir="build/testoutput"/>
</junitreport>
<fail if="junit.failure"
message="Unit tests failed. See build/testoutput/index.html" />
</target>
<target name="fuzz-test"
depends="all-classes-jar"
description="checks the compiler against a variety of js programs">
<exec executable="java" failonerror="true">
<arg value="-cp" />
<arg value="${compiler-jarfile}" />
<arg value="com.google.javascript.jscomp.regtests.CompileEachLineOfProgramOutput" />
<arg value="generatejs"/>
<arg value="--stdout"/>
<arg value="${num-fuzz-tests}"/>
</exec>
</target>
<target name="javadoc"
description="generate Javadoc"
depends="rhino-jarjar">
<mkdir dir="${javadoc.dir}" />
<javadoc
destdir="${javadoc.dir}"
author="false"
protected="true"
windowtitle="Compiler"
additionalparam=" -notimestamp "
stylesheetfile="${stylesheetfile}">
<sourcepath>
<pathelement location="${src.dir}" />
<pathelement location="${gen.dir}" />
</sourcepath>
<classpath refid="allclasspath.path" />
<link href="http://java.sun.com/javase/6/docs/api/" />
<bottom><![CDATA[
<div id="footer">
<div id="footerlogo">
<img src="http://www.google.com/images/art.gif"
alt="Google colored balls">
</div>
<div id="copyright">
<p>&copy; 2009 Google -
<a href="http://www.google.com/privacy.html">Privacy Policy</a> -
<a href="http://www.google.com/terms_of_service.html">Terms and Conditions</a> -
<a href="http://www.google.com/about.html">About Google</a>
</p>
</div>
</div>
]]>
</bottom>
</javadoc>
</target>
<target name="jar-javadoc" depends="javadoc">
<jar jarfile="${compiler-jarfile-javadoc}">
<fileset dir="${javadoc.dir}" />
</jar>
</target>
<target name="jar-sources" depends="javadoc">
<jar jarfile="${compiler-jarfile-sources}">
<fileset dir="${src.dir}" />
<fileset dir="${gen.dir}" />
</jar>
</target>
<!-- JsonML package related targets -->
<!-- set the classpath for the project -->
<!-- this includes the generated source class files -->
<!-- and every jar in the /lib directory -->
<path id="jsonml-classpath.path">
<pathelement location="${classes.dir}" />
<fileset dir="${lib.dir}">
<include name="*.jar" />
</fileset>
<fileset dir="${classes.dir}">
<include name="*.class" />
</fileset>
<fileset dir="${buildlib.dir}">
<include name="rhino.jar"/>
</fileset>
</path>
<target name="jsonml-compile"
description="compile the source code of classes from JsonML package"
depends="compile">
<mkdir dir="${jsonml-classes.dir}" />
<javac debug="true" srcdir="${jsonml.dir}"
destdir="${jsonml-classes.dir}"
excludes=".svn"
>
<classpath refid="jsonml-classpath.path" />
</javac>
</target>
<target name="jsonml-jar"
description="package the compiler and JsonML classes"
depends="jsonml-compile, compile">
<zip destfile="${build.dir}/externs.zip" basedir="${externs.dir}" includes="*.js" />
<jar destfile="${jsonml-jarfile}" update="true">
<zipgroupfileset dir="${lib.dir}" includes="*.jar"/>
<zipfileset src="${buildlib.dir}/rhino.jar"/>
<fileset dir="${classes.dir}" />
<fileset dir="${jsonml-classes.dir}" />
</jar>
</target>
<target name="webservice-compile"
description="compile the source code of classes from the webservice package"
depends="compile">
<mkdir dir="${webservice-classes.dir}" />
<javac debug="true" srcdir="${webservice.dir}"
destdir="${webservice-classes.dir}"
excludes=".svn"
>
<classpath refid="jsonml-classpath.path" />
</javac>
</target>
<target name="webservice-jar"
description="package the compiler and Webservice classes"
depends="webservice-compile, compile">
<zip destfile="${build.dir}/externs.zip" basedir="${externs.dir}" includes="*.js" />
<jar destfile="${webservice-jarfile}" update="true">
<zipgroupfileset dir="${lib.dir}" includes="*.jar"/>
<zipfileset src="${buildlib.dir}/rhino.jar"/>
<fileset dir="${classes.dir}" />
<fileset dir="${webservice-classes.dir}" />
</jar>
</target>
</project>

View File

@ -0,0 +1,177 @@
<!--
Copyright 2009 Google Inc.
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.
-->
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<modelVersion>4.0.0</modelVersion>
<groupId>com.google.javascript</groupId>
<artifactId>closure-compiler</artifactId>
<packaging>jar</packaging>
<name>Closure Compiler</name>
<version>r@build.svnVersion@</version>
<url>http://code.google.com/p/closure-compiler/</url>
<description>
Closure Compiler is a JavaScript optimizing compiler. It parses your
JavaScript, analyzes it, removes dead code and rewrites and minimizes
what's left. It also checks syntax, variable references, and types, and
warns about common JavaScript pitfalls. It is used in many of Google's
JavaScript apps, including Gmail, Google Web Search, Google Maps, and
Google Docs.
</description>
<inceptionYear>2009</inceptionYear>
<scm>
<connection>
scm:svn:http://closure-compiler.googlecode.com/svn/trunk
</connection>
<developerConnection>
scm:svn:https://closure-compiler.googlecode.com/svn/trunk
</developerConnection>
<url>
http://code.google.com/p/closure-compiler/source/browse/#svn/trunk
</url>
</scm>
<issueManagement>
<system>code.google.com</system>
<url>http://code.google.com/p/closure-compiler/issues</url>
</issueManagement>
<organization>
<name>Google</name>
<url>http://www.google.com</url>
</organization>
<licenses>
<license>
<name>The Apache Software License, Version 2.0</name>
<url>http://www.apache.org/licenses/LICENSE-2.0.html</url>
<distribution>repo</distribution>
</license>
</licenses>
<repositories>
<repository>
<id>central</id>
<name>Maven Repository Switchboard</name>
<layout>default</layout>
<url>http://repo1.maven.org/maven2</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
<repository>
<id>caja</id>
<url>http://google-caja.googlecode.com/svn/maven</url>
</repository>
</repositories>
<developers>
<developer>
<id>johnlenz</id>
<name>John Lenz</name>
<email>concavelenz@gmail.com</email>
</developer>
<developer>
<id>nicksantos</id>
<name>Nick Santos</name>
<email>nicholas.j.santos@gmail.com</email>
</developer>
<developer>
<id>acleung</id>
<name>Alan Leung</name>
<email>acleung@gmail.com</email>
</developer>
<developer>
<id>mbolin</id>
<name>Michael Bolin</name>
<email>mbolin@alum.mit.edu</email>
</developer>
<developer>
<id>plindner</id>
<name>Paul Lindner</name>
<email>lindner@inuus.com</email>
</developer>
</developers>
<dependencies>
<dependency>
<groupId>args4j</groupId>
<artifactId>args4j</artifactId>
<version>2.0.16</version>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>13.0.1</version>
</dependency>
<dependency>
<groupId>com.google.protobuf</groupId>
<artifactId>protobuf-java</artifactId>
<version>2.4.1</version>
</dependency>
<dependency>
<groupId>org.json</groupId>
<artifactId>json</artifactId>
<version>20090211</version>
</dependency>
<dependency>
<groupId>org.apache.ant</groupId>
<artifactId>ant</artifactId>
<version>1.8.2</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>com.google.code.findbugs</groupId>
<artifactId>jsr305</artifactId>
<version>1.3.9</version>
</dependency>
<dependency>
<groupId>com.googlecode.jarjar</groupId>
<artifactId>jarjar</artifactId>
<version>1.1</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.10</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>caja</groupId>
<artifactId>caja</artifactId>
<version>r4939</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,288 @@
/*
* Copyright 2010 Google Inc.
*
* 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.
*/
/**
* @fileoverview External declarations for common container JS.
*
* TODO(uix-eng): May want a way to conveniently generate this externs to avoid
* manual changes when we merge Shindig.
*
* @externs
*/
google.container = {};
////////////////////////////////////////////////////////////////////////////////
// Externs from container.js
////////////////////////////////////////////////////////////////////////////////
google.container.ContainerConfig = {};
google.container.ContainerRender = {};
/**
* @param {Object} config
* @constructor
*/
google.container.Container = function(config) {};
/**
* @param {Object=} opt_config
*/
google.container.Container.prototype.onConstructed = function(opt_config) {};
/**
* Create a new gadget site.
* @param {Element} gadgetEl
* @param {Element=} opt_bufferEl
* @return {google.container.GadgetSite}
*/
google.container.Container.prototype.newGadgetSite = function(gadgetEl,
opt_bufferEl) {};
/**
* @param {string} id
* @return {google.container.GadgetSite}
* @nosideeffects
*/
google.container.Container.prototype.getGadgetSite = function(id) {};
/**
* @param {string} id
* @return {google.container.GadgetHolder}
* @nosideeffects
*/
google.container.Container.prototype.getGadgetHolder = function(id) {};
/**
* @param {google.container.GadgetSite} site
* @param {string} gadgetUrl
* @param {Object} gadgetParams
* @param {Object} renderParams
* @param {Function=} opt_callback
*/
google.container.Container.prototype.navigateGadget = function(
site, gadgetUrl, gadgetParams, renderParams, opt_callback) {};
/**
* @param {google.container.GadgetSite} site
*/
google.container.Container.prototype.closeGadget = function(site) {};
/**
* @param {Object} request
*/
google.container.Container.prototype.preloadGadgets = function(request) {};
/**
* @param {string} url
* @param {function(Object)=} opt_callback
*/
google.container.Container.prototype.getGadgetMetadata = function(url,
opt_callback) {};
////////////////////////////////////////////////////////////////////////////////
// Externs from gadget_site.js
////////////////////////////////////////////////////////////////////////////////
/**
* @param {google.container.Service} service
* @param {Element} gadgetEl
* @param {Element=} opt_bufferEl
* @constructor
*/
google.container.GadgetSite = function(service, gadgetEl, opt_bufferEl) {};
google.container.GadgetSite.prototype.onConstructed = function() {};
/**
* @param {number} height
*/
google.container.GadgetSite.prototype.setHeight = function(height) {};
/**
* @param {number} width
*/
google.container.GadgetSite.prototype.setWidth = function(width) {};
/**
* @param {number} value
*/
google.container.GadgetSite.prototype.setParentId = function(value) {};
/**
* @return {number}
* @nosideeffects
*/
google.container.GadgetSite.prototype.getId = function() {};
/**
* @return {google.container.GadgetHolder}
* @nosideeffects
*/
google.container.GadgetSite.prototype.getActiveGadgetHolder = function() {};
/**
* @param {string} name
* @param {Object=} opt_gadgetInfo
* @return {Object}
* @nosideeffects
*/
google.container.GadgetSite.prototype.getFeature = function(name,
opt_gadgetInfo) {};
/**
* @param {string} id
* @return {google.container.GadgetHolder}
* @nosideeffects
*/
google.container.GadgetSite.prototype.getGadgetHolder = function(id) {};
/**
* @return {string}
* @nosideeffects
*/
google.container.GadgetSite.prototype.getParentId = function() {};
/**
* @param {string} gadgetUrl
* @param {Object} gadgetParams
* @param {Object} renderParams
* @param {Function=} opt_callback
*/
google.container.GadgetSite.prototype.navigateTo = function(gadgetUrl,
gadgetParams, renderParams, opt_callback) {};
/**
* @param {Object} gadgetInfo
* @param {Object} gadgetParams
* @param {Object} renderParams
*/
google.container.GadgetSite.prototype.render = function(
gadgetInfo, gadgetParams, renderParams) {};
/**
* @param {string} serviceName
* @param {Function} callback
* @param {...number} var_args
*/
google.container.GadgetSite.prototype.rpcCall = function(serviceName, callback,
var_args) {};
google.container.GadgetSite.prototype.close = function() {};
////////////////////////////////////////////////////////////////////////////////
// Externs from gadget_holder.js
////////////////////////////////////////////////////////////////////////////////
/**
* @param {number} siteId
* @param {Element} el
* @constructor
*/
google.container.GadgetHolder = function(siteId, el) {};