ClassSet.java

  1. /*
  2.  * Licensed to the Apache Software Foundation (ASF) under one or more
  3.  * contributor license agreements.  See the NOTICE file distributed with
  4.  * this work for additional information regarding copyright ownership.
  5.  * The ASF licenses this file to You under the Apache License, Version 2.0
  6.  * (the "License"); you may not use this file except in compliance with
  7.  * the License.  You may obtain a copy of the License at
  8.  *
  9.  *      http://www.apache.org/licenses/LICENSE-2.0
  10.  *
  11.  *  Unless required by applicable law or agreed to in writing, software
  12.  *  distributed under the License is distributed on an "AS IS" BASIS,
  13.  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14.  *  See the License for the specific language governing permissions and
  15.  *  limitations under the License.
  16.  */
  17. package org.apache.bcel.util;

  18. import java.util.HashMap;
  19. import java.util.Map;

  20. import org.apache.bcel.classfile.JavaClass;
  21. import org.apache.commons.lang3.ArrayUtils;

  22. /**
  23.  * Utility class implementing a (type-safe) set of JavaClass objects. Since JavaClass has no equals() method, the name of the class is used for comparison.
  24.  *
  25.  * @see ClassStack
  26.  */
  27. public class ClassSet {

  28.     private final Map<String, JavaClass> map = new HashMap<>();

  29.     public boolean add(final JavaClass clazz) {
  30.         return map.putIfAbsent(clazz.getClassName(), clazz) != null;
  31.     }

  32.     public boolean empty() {
  33.         return map.isEmpty();
  34.     }

  35.     public String[] getClassNames() {
  36.         return map.keySet().toArray(ArrayUtils.EMPTY_STRING_ARRAY);
  37.     }

  38.     public void remove(final JavaClass clazz) {
  39.         map.remove(clazz.getClassName());
  40.     }

  41.     public JavaClass[] toArray() {
  42.         return map.values().toArray(JavaClass.EMPTY_ARRAY);
  43.     }
  44. }