com.google.javascript.jscomp.modules.UnresolvedModule Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of closure-compiler-unshaded Show documentation
Show all versions of closure-compiler-unshaded Show documentation
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.
/*
* Copyright 2019 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.
*/
package com.google.javascript.jscomp.modules;
import com.google.common.collect.ImmutableSet;
import com.google.javascript.jscomp.modules.ModuleMetadataMap.ModuleMetadata;
import java.util.HashSet;
import java.util.Set;
import javax.annotation.Nullable;
/**
* A module which has had some of its imports and exports statements scanned but has yet to resolve
* anything transitively.
*/
abstract class UnresolvedModule {
/**
* Clears any caching so that {@link #resolve(ModuleRequestResolver)} will create a new Module.
*/
abstract void reset();
final Module resolve(ModuleRequestResolver moduleRequestResolver) {
return resolve(moduleRequestResolver, /* moduleSpecifier= */ null);
}
/**
* Resolves all imports and exports and returns a resolved module.
*
* @param moduleSpecifier the module specifier that was used to import this module, if resolving
* an import
*/
abstract Module resolve(
ModuleRequestResolver moduleRequestResolver, @Nullable String moduleSpecifier);
/** Returns the metadata corresponding to this module */
abstract ModuleMetadata metadata();
/**
* Returns all names in this module's namespace. Names are sorted per Java's string ordering,
* which should be the same as JavaScript's Array.protype.sort, which is how the spec says these
* keys should be ordered in the ES module object.
*/
abstract ImmutableSet getExportedNames(ModuleRequestResolver moduleRequestResolver);
/**
* Returns all names in this module's namespace. Names are sorted per Java's string ordering,
* which should be the same as JavaScript's Array.prototype.sort, which is how the spec says these
* keys should be ordered in the ES module object.
*
* @param visited set used to detect {@code export *} cycles.
*/
protected abstract ImmutableSet getExportedNames(
ModuleRequestResolver moduleRequestResolver, Set visited);
/**
* @param exportName name of the export to resolve
* @return the result of resolving the export, which can be one of several states:
*
* - The resolved export with the binding, if found.
*
- A result indicating that the export is ambiguous.
*
- A result indicating that the module has no such export.
*
- A result indicating that there was some other error resolving, like a cycle, or a
* module transitively returned that there was no such export.
*
*/
ResolveExportResult resolveExport(
ModuleRequestResolver moduleRequestResolver, String exportName) {
return resolveExport(
moduleRequestResolver,
/* moduleSpecifier= */ null,
exportName,
new HashSet<>(),
new HashSet<>());
}
/**
* @param moduleSpecifier the specifier used to reference this module, if this trace is from an
* import
* @param exportName name of the export to resolve
* @param resolveSet set used to detect invalid cycles. It is invalid to reach the same exact
* export (same module with the same export name) in a given cycle.
* @param exportStarSet set used for cycle checking with {@code export *} statements
* @return the result of resolving the export, which can be one of several states:
*
* - The resolved export with the binding, if found.
*
- A result indicating that the export is ambiguous.
*
- A result indicating that the module has no such export.
*
- A result indicating that there was some other error resolving, like a cycle, or a
* module transitively returned that there was no such export.
*
*/
abstract ResolveExportResult resolveExport(
ModuleRequestResolver moduleRequestResolver,
@Nullable String moduleSpecifier,
String exportName,
Set resolveSet,
Set exportStarSet);
// Reference equality is expected in ExportTrace. Prevent subclasses from changing this.
@Override
public final boolean equals(Object other) {
return super.equals(other);
}
@Override
public final int hashCode() {
return super.hashCode();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy