• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

Java UnionFind类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了Java中com.google.javascript.jscomp.graph.UnionFind的典型用法代码示例。如果您正苦于以下问题:Java UnionFind类的具体用法?Java UnionFind怎么用?Java UnionFind使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。



UnionFind类属于com.google.javascript.jscomp.graph包,在下文中一共展示了UnionFind类的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Java代码示例。

示例1: buildPropNames

import com.google.javascript.jscomp.graph.UnionFind; //导入依赖的package包/类
/**
 * Chooses a name to use for renaming in each equivalence class and maps
 * the representative type of that class to that name.
 */
private Map<TypeI, String> buildPropNames(Property prop) {
  UnionFind<TypeI> pTypes = prop.getTypes();
  String pname = prop.name;
  Map<TypeI, String> names = new HashMap<>();
  for (Set<TypeI> set : pTypes.allEquivalenceClasses()) {
    checkState(!set.isEmpty());
    TypeI representative = pTypes.find(set.iterator().next());
    String typeName = null;
    for (TypeI type : set) {
      String typeString = type.toString();
      if (typeName == null || typeString.compareTo(typeName) < 0) {
        typeName = typeString;
      }
    }
    String newName;
    if ("{...}".equals(typeName)) {
      newName = pname;
    } else {
      newName = NONWORD_PATTERN.matcher(typeName).replaceAll("_") + '$' + pname;
    }
    names.put(representative, newName);
  }
  return names;
}
 
开发者ID:google,项目名称:closure-compiler,代码行数:29,代码来源:DisambiguateProperties.java


示例2: getTypes

import com.google.javascript.jscomp.graph.UnionFind; //导入依赖的package包/类
/** Returns the types on which this field is referenced. */
UnionFind<T> getTypes() {
  if (types == null) {
    types = new StandardUnionFind<T>();
  }
  return types;
}
 
开发者ID:andyjko,项目名称:feedlack,代码行数:8,代码来源:DisambiguateProperties.java


示例3: renameProperties

import com.google.javascript.jscomp.graph.UnionFind; //导入依赖的package包/类
/** Renames all properties with references on more than one type. */
void renameProperties() {
  int propsRenamed = 0, propsSkipped = 0, instancesRenamed = 0,
      instancesSkipped = 0, singleTypeProps = 0;

  for (Property prop : properties.values()) {
    if (prop.shouldRename()) {
      Map<T, String> propNames = buildPropNames(prop.getTypes(), prop.name);

      ++propsRenamed;
      prop.expandTypesToSkip();
      UnionFind<T> types = prop.getTypes();
      for (Node node : prop.renameNodes) {
        T rootType = prop.rootTypes.get(node);
        if (prop.shouldRename(rootType)) {
          String newName = propNames.get(rootType);
          node.setString(newName);
          compiler.reportCodeChange();
          ++instancesRenamed;
        } else {
          ++instancesSkipped;
        }
      }
    } else {
      if (prop.skipRenaming) {
        ++propsSkipped;
      } else {
        ++singleTypeProps;
      }
    }
  }
  logger.info("Renamed " + instancesRenamed + " instances of "
              + propsRenamed + " properties.");
  logger.info("Skipped renaming " + instancesSkipped + " invalidated "
              + "properties, " + propsSkipped + " instances of properties "
              + "that were skipped for specific types and " + singleTypeProps
              + " properties that were referenced from only one type.");
}
 
开发者ID:andyjko,项目名称:feedlack,代码行数:39,代码来源:DisambiguateProperties.java


示例4: renameProperties

import com.google.javascript.jscomp.graph.UnionFind; //导入依赖的package包/类
/** Renames all properties with references on more than one type. */
void renameProperties() {
  int propsRenamed = 0, propsSkipped = 0, instancesRenamed = 0,
      instancesSkipped = 0, singleTypeProps = 0;

  for (Property prop : properties.values()) {
    if (prop.shouldRename()) {
      Map<T, String> propNames = buildPropNames(prop.getTypes(), prop.name);

      ++propsRenamed;
      prop.expandTypesToSkip();
      UnionFind<T> types = prop.getTypes();
      for (Node node : prop.renameNodes) {
        T rootType = prop.rootTypes.get(node);
        if (prop.shouldRename(rootType)) {
          String newName = propNames.get(rootType);
          node.setString(newName);
          compiler.reportCodeChange();
          ++instancesRenamed;
        } else {
          ++instancesSkipped;
        }
      }
    } else {
      if (prop.skipRenaming) {
        ++propsSkipped;
      } else {
        ++singleTypeProps;
      }
    }
  }
  logger.fine("Renamed " + instancesRenamed + " instances of "
              + propsRenamed + " properties.");
  logger.fine("Skipped renaming " + instancesSkipped + " invalidated "
              + "properties, " + propsSkipped + " instances of properties "
              + "that were skipped for specific types and " + singleTypeProps
              + " properties that were referenced from only one type.");
}
 
开发者ID:SpoonLabs,项目名称:astor,代码行数:39,代码来源:DisambiguateProperties.java


示例5: getTypes

import com.google.javascript.jscomp.graph.UnionFind; //导入依赖的package包/类
/** Returns the types on which this field is referenced. */
UnionFind<TypeI> getTypes() {
  if (types == null) {
    types = new StandardUnionFind<>();
  }
  return types;
}
 
开发者ID:google,项目名称:closure-compiler,代码行数:8,代码来源:DisambiguateProperties.java


示例6: getTypes

import com.google.javascript.jscomp.graph.UnionFind; //导入依赖的package包/类
/** Returns the types on which this field is referenced. */
UnionFind<T> getTypes() {
  if (types == null) {
    types = new StandardUnionFind<>();
  }
  return types;
}
 
开发者ID:nicks,项目名称:closure-compiler-old,代码行数:8,代码来源:DisambiguateProperties.java


示例7: renameProperties

import com.google.javascript.jscomp.graph.UnionFind; //导入依赖的package包/类
/** Renames all properties with references on more than one type. */
void renameProperties() {
  int propsRenamed = 0;
  int propsSkipped = 0;
  int instancesRenamed = 0;
  int instancesSkipped = 0;
  int singleTypeProps = 0;

  Set<String> reported = new HashSet<>();
  for (Property prop : properties.values()) {
    if (prop.shouldRename()) {
      UnionFind<TypeI> pTypes = prop.getTypes();
      Map<TypeI, String> propNames = buildPropNames(prop);

      ++propsRenamed;
      prop.expandTypesToSkip();
      // This loop has poor locality, because instead of walking the AST,
      // we iterate over all accesses of a property, which can be in very
      // different places in the code.
      for (Map.Entry<Node, TypeI> entry : prop.rootTypesByNode.entrySet()) {
        Node node = entry.getKey();
        TypeI rootType = entry.getValue();
        if (prop.shouldRename(rootType)) {
          String newName = propNames.get(pTypes.find(rootType));
          node.setString(newName);
          compiler.reportChangeToEnclosingScope(node);
          ++instancesRenamed;
        } else {
          ++instancesSkipped;

          CheckLevel checkLevelForProp = propertiesToErrorFor.get(prop.name);
          if (checkLevelForProp != null
              && checkLevelForProp != CheckLevel.OFF
              && !reported.contains(prop.name)) {
            reported.add(prop.name);
            compiler.report(JSError.make(
                node,
                checkLevelForProp,
                Warnings.INVALIDATION_ON_TYPE, prop.name,
                rootType.toString(), ""));
          }
        }
      }
    } else {
      if (prop.skipRenaming) {
        ++propsSkipped;
      } else {
        ++singleTypeProps;
      }
    }
  }
  if (logger.isLoggable(Level.FINE)) {
    logger.fine("Renamed " + instancesRenamed + " instances of "
                + propsRenamed + " properties.");
    logger.fine("Skipped renaming " + instancesSkipped + " invalidated "
                + "properties, " + propsSkipped + " instances of properties "
                + "that were skipped for specific types and " + singleTypeProps
                + " properties that were referenced from only one type.");
  }
}
 
开发者ID:google,项目名称:closure-compiler,代码行数:61,代码来源:DisambiguateProperties.java



注:本文中的com.google.javascript.jscomp.graph.UnionFind类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Java WebSocketFrame类代码示例发布时间:2022-05-23
下一篇:
Java TileEntityMobSpawner类代码示例发布时间:2022-05-23
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap