1 /* 2 * ProGuard -- shrinking, optimization, obfuscation, and preverification 3 * of Java bytecode. 4 * 5 * Copyright (c) 2002-2014 Eric Lafortune (eric@graphics.cornell.edu) 6 * 7 * This program is free software; you can redistribute it and/or modify it 8 * under the terms of the GNU General Public License as published by the Free 9 * Software Foundation; either version 2 of the License, or (at your option) 10 * any later version. 11 * 12 * This program is distributed in the hope that it will be useful, but WITHOUT 13 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 14 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 15 * more details. 16 * 17 * You should have received a copy of the GNU General Public License along 18 * with this program; if not, write to the Free Software Foundation, Inc., 19 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 20 */ 21 package proguard.classfile.visitor; 22 23 import proguard.classfile.ClassPool; 24 25 26 /** 27 * This ClassPoolVisitor delegates all visits to each ClassPoolVisitor 28 * in a given list. 29 * 30 * @author Eric Lafortune 31 */ 32 public class MultiClassPoolVisitor implements ClassPoolVisitor 33 { 34 private static final int ARRAY_SIZE_INCREMENT = 5; 35 36 private ClassPoolVisitor[] classPoolVisitors; 37 private int classPoolVisitorCount; 38 39 MultiClassPoolVisitor()40 public MultiClassPoolVisitor() 41 { 42 } 43 44 MultiClassPoolVisitor(ClassPoolVisitor[] classPoolVisitors)45 public MultiClassPoolVisitor(ClassPoolVisitor[] classPoolVisitors) 46 { 47 this.classPoolVisitors = classPoolVisitors; 48 this.classPoolVisitorCount = classPoolVisitors.length; 49 } 50 51 addClassPoolVisitor(ClassPoolVisitor classPoolVisitor)52 public void addClassPoolVisitor(ClassPoolVisitor classPoolVisitor) 53 { 54 ensureArraySize(); 55 56 classPoolVisitors[classPoolVisitorCount++] = classPoolVisitor; 57 } 58 59 ensureArraySize()60 private void ensureArraySize() 61 { 62 if (classPoolVisitors == null) 63 { 64 classPoolVisitors = new ClassPoolVisitor[ARRAY_SIZE_INCREMENT]; 65 } 66 else if (classPoolVisitors.length == classPoolVisitorCount) 67 { 68 ClassPoolVisitor[] newClassPoolVisitors = 69 new ClassPoolVisitor[classPoolVisitorCount + 70 ARRAY_SIZE_INCREMENT]; 71 System.arraycopy(classPoolVisitors, 0, 72 newClassPoolVisitors, 0, 73 classPoolVisitorCount); 74 classPoolVisitors = newClassPoolVisitors; 75 } 76 } 77 78 79 // Implementations for ClassPoolVisitor. 80 visitClassPool(ClassPool classPool)81 public void visitClassPool(ClassPool classPool) 82 { 83 for (int index = 0; index < classPoolVisitorCount; index++) 84 { 85 classPoolVisitors[index].visitClassPool(classPool); 86 } 87 } 88 } 89