All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.javascript.rhino.TypeIRegistry Maven / Gradle / Ivy

Go to download

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.

There is a newer version: v20240317
Show newest version
/*
 *
 * ***** BEGIN LICENSE BLOCK *****
 * Version: MPL 1.1/GPL 2.0
 *
 * The contents of this file are subject to the Mozilla Public License Version
 * 1.1 (the "License"); you may not use this file except in compliance with
 * the License. You may obtain a copy of the License at
 * http://www.mozilla.org/MPL/
 *
 * Software distributed under the License is distributed on an "AS IS" basis,
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
 * for the specific language governing rights and limitations under the
 * License.
 *
 * The Original Code is Rhino code, released
 * May 6, 1999.
 *
 * The Initial Developer of the Original Code is
 * Netscape Communications Corporation.
 * Portions created by the Initial Developer are Copyright (C) 1997-1999
 * the Initial Developer. All Rights Reserved.
 *
 * Contributor(s):
 *   Ben Lickly
 *   Dimitris Vardoulakis
 *
 * Alternatively, the contents of this file may be used under the terms of
 * the GNU General Public License Version 2 or later (the "GPL"), in which
 * case the provisions of the GPL are applicable instead of those above. If
 * you wish to allow use of your version of this file only under the terms of
 * the GPL and not to allow others to use your version of this file under the
 * MPL, indicate your decision by deleting the provisions above and replacing
 * them with the notice and other provisions required by the GPL. If you do
 * not delete the provisions above, a recipient may use your version of this
 * file under either the MPL or the GPL.
 *
 * ***** END LICENSE BLOCK ***** */

package com.google.javascript.rhino;

import com.google.common.collect.ImmutableList;
import com.google.javascript.rhino.jstype.JSTypeNative;
import java.io.Serializable;
import java.util.List;
import java.util.Map;

/**
 * @author [email protected] (Ben Lickly)
 * @author [email protected] (Dimitris Vardoulakis)
 */
public interface TypeIRegistry extends Serializable {
  // TODO(dimvar): Some methods in this interface are polymorphic because they are used
  // in compiler passes mixed with the old type system.
  // Polymorphism avoids the need for casting in many cases (fewer casts in java 8 than in java 7).
  // After all non-type-checking passes use TypeI, we should make these methods not polymorphic.
  //
  // We considered defining the interface as TypeIRegistry, but it would only
  // help with getNativeType and getType, not with the other methods, and it would increase
  // verbosity in all places that use the interface.

  TypeI createTypeFromCommentNode(Node n);

  FunctionTypeI getNativeFunctionType(JSTypeNative typeId);

  ObjectTypeI getNativeObjectType(JSTypeNative typeId);

  TypeI getNativeType(JSTypeNative typeId);

  String getReadableTypeName(Node n);

  /**
   * For NTI, this method returns an obfuscated name that represents the getter.
   * For OTI, the property name is unchanged.
   */
  String createGetterPropName(String originalPropName);

  /**
   * For NTI, this method returns an obfuscated name that represents the setter.
   * For OTI, the property name is unchanged.
   *
   * This method is a bit of a hack. In the future, NTI can handle getters/setters more
   * gracefully by having a field in the Property class.
   * See also: https://github.com/google/closure-compiler/issues/2545.
   */
  String createSetterPropName(String originalPropName);

  /**
   * Returns the type represented by typeName or null if not found.
   *
   * If you pass Foo to this method, and Foo can be an instance or a constructor,
   * you get the Foo instance, in contrast to TypeIEnv#getNamespaceType,
   * where you'd get the Foo constructor.
   *
   * If Foo is not a nominal type, returns the namespace type.
   */
  TypeI getType(StaticScope scope, String typeName);

  /**
   * Returns the type represented by typeName or null if not found.
   *
   * If you pass Foo to this method, and Foo can be an instance or a constructor,
   * you get the Foo instance, in contrast to TypeIEnv#getNamespaceType,
   * where you'd get the Foo constructor.
   *
   * If Foo is not a nominal type, returns the namespace type.
   *
   * @deprecated Use #getGlobalType instead.
   */
   @Deprecated
   TypeI getType(String typeName);

  /**
   * Returns the type represented by typeName or null if not found.
   *
   * If you pass Foo to this method, and Foo can be an instance or a constructor,
   * you get the Foo instance, in contrast to TypeIEnv#getNamespaceType,
   * where you'd get the Foo constructor.
   *
   * If Foo is not a nominal type, returns the namespace type.
   */
  TypeI getGlobalType(String typeName);

  TypeI createUnionType(List variants);

  /**
   * Creates an anonymous structural type with the given properties.
   */
  TypeI createRecordType(Map props);

  /**
   * Instantiates genericType using typeArgs.
   * If genericType has fewer type variables than the number of typeArgs, we pad with unknown.
   * If it has more, we drop the extra typeArgs.
   * TODO(dimvar): fix the callers to pass the right number of typeArgs and throw here.
   */
  TypeI instantiateGenericType(ObjectTypeI genericType, ImmutableList typeArgs);

  TypeI evaluateTypeExpressionInGlobalScope(JSTypeExpression expr);

  TypeI evaluateTypeExpression(JSTypeExpression expr, TypeIEnv typeEnv);

  TypeI buildRecordTypeFromObject(ObjectTypeI obj);
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy