com.google.gwt.soyc.GlobalInformation Maven / Gradle / Ivy
/*
* Copyright 2008 Google Inc.
*
* 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.gwt.soyc;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.TreeMap;
import java.util.TreeSet;
/**
* Compile Report information about a compiled module.
*/
public class GlobalInformation {
private static final SizeBreakdown[] EMPTY_SIZE_BREAKDOWN = new SizeBreakdown[0];
public Map> dependencies = null;
private Map classToPackage = new TreeMap();
private HashMap> classToWhatItDependsOn = new HashMap>();
private Map exclusiveCodeBreakdowns = new HashMap();
private SizeBreakdown initialCodeBreakdown = new SizeBreakdown(
"Initially downloaded code", "initial");
private SizeBreakdown leftoversBreakdown = new SizeBreakdown(
"Leftovers code, code not in any other split point", "leftovers");
private int numSplitPoints = 0;
private Map> packageToClasses = new TreeMap>();
private final String permutationId;
private ArrayList splitPointInitialLoadSequence = new ArrayList();
private HashMap splitPointToLocation = new HashMap();
private SizeBreakdown totalCodeBreakdown = new SizeBreakdown("Total program",
"total");
public GlobalInformation(String permutationId) {
this.permutationId = permutationId;
}
public SizeBreakdown[] allSizeBreakdowns() {
List breakdowns = new ArrayList();
breakdowns.add(totalCodeBreakdown);
breakdowns.add(initialCodeBreakdown);
if (numSplitPoints > 0) {
breakdowns.add(leftoversBreakdown);
for (int sp = 1; sp <= numSplitPoints; sp++) {
breakdowns.add(splitPointCodeBreakdown(sp));
}
}
return breakdowns.toArray(EMPTY_SIZE_BREAKDOWN);
}
/**
* Computes all package sizes.
*/
public void computePackageSizes() {
for (SizeBreakdown breakdown : allSizeBreakdowns()) {
computePackageSizes(breakdown.packageToSize, breakdown.classToSize);
}
}
/**
* Gets the mapping from each class to its package.
*
* @return classToPackage
*/
public final Map getClassToPackage() {
return classToPackage;
}
/**
* Gets the mapping from a class to what it depends on.
*
* @return classToWhatItDependsOn
*/
public final HashMap> getClassToWhatItDependsOn() {
return classToWhatItDependsOn;
}
/**
* Gets the exclusive code breakdown.
*
* @return exclusiveCodeBreakdown
*/
public final Map getExclusiveCodeBreakdowns() {
return exclusiveCodeBreakdowns;
}
/**
* Gets the initial code breakdown.
*
* @return initialCodeBreakdown
*/
public final SizeBreakdown getInitialCodeBreakdown() {
return initialCodeBreakdown;
}
/**
* Gets the leftovers code breakdown.
*
* @return leftoversCodeBreakdown
*/
public final SizeBreakdown getLeftoversBreakdown() {
return leftoversBreakdown;
}
/**
* Gets the number of split points.
*
* @return numSplitPoints
*/
public final int getNumSplitPoints() {
return numSplitPoints;
}
/**
* Gets the mapping from packages to classes.
*
* @return packageToClasses
*/
public final Map> getPackageToClasses() {
return packageToClasses;
}
public String getPermutationId() {
return permutationId;
}
/**
* Gets the initial load sequence.
*
* @return splitPointInitialLoadSequence
*/
public final ArrayList getSplitPointInitialLoadSequence() {
return splitPointInitialLoadSequence;
}
/**
* Gets the mapping from split points to locations where they were set.
*
* @return splitPointToLocation
*/
public final HashMap getSplitPointToLocation() {
return splitPointToLocation;
}
/**
* Gets the total code breakdown.
*
* @return totalCodeBreakdown
*/
public final SizeBreakdown getTotalCodeBreakdown() {
return totalCodeBreakdown;
}
/**
* Increments the split point count.
*/
public final void incrementSplitPoints() {
numSplitPoints++;
}
/**
* Gets an exclusive code breakdown for a split point.
*
* @param sp split point
* @return exlusive code breakdown for sp
*/
public SizeBreakdown splitPointCodeBreakdown(int sp) {
assert sp >= 1 && sp <= numSplitPoints;
if (!exclusiveCodeBreakdowns.containsKey(sp)) {
exclusiveCodeBreakdowns.put(sp, new SizeBreakdown("split point " + sp
+ ": " + splitPointToLocation.get(sp), "sp" + sp));
}
return exclusiveCodeBreakdowns.get(sp);
}
/**
* Computes package sizes from class sizes. TODO(spoon) move this to the
* SizeBreakdown class.
*
* @param packageToSize mapping from packages to their sizes
* @param classToSize mapping from classes to their sizes
*/
private void computePackageSizes(Map packageToSize,
Map classToSize) {
packageToSize.clear();
for (String packageName : packageToClasses.keySet()) {
packageToSize.put(packageName, 0);
for (String className : packageToClasses.get(packageName)) {
if (classToSize.containsKey(className)) {
int curSize = classToSize.get(className);
int newSize = curSize + packageToSize.get(packageName);
packageToSize.put(packageName, newSize);
}
}
}
}
}