This method is used to print the result in various
*ArchiveClassesLoadable tests.
StringBuilder sb = new StringBuilder();
sb.append("\n");
for (Object o : cc.getFailed().entrySet()) {
Map.Entry<String, List<String>> referencingPathToFailedList =
(Map.Entry<String, List<String>>)o;
LocalStringManagerImpl smh = StringManagerHelper.getLocalStringsManager();
String classes = "Failed to find following classes:";
if (smh != null) {
classes = smh.getLocalString(
ArchiveClassesLoadableHelper.class.getName() + ".classes",
classes);
}
sb.append(classes).append("\n[");
for (Iterator<String> iii = referencingPathToFailedList.getValue().iterator();
iii.hasNext();) {
sb.append("\n\t").append(iii.next());
if(iii.hasNext()) sb.append(",");
}
sb.append("\n]");
String referencingPath = referencingPathToFailedList.getKey();
if(referencingPath.length()==0) continue; // skip if a top level class is not found
String ref = "referenced in the following call stack :\n";
String reference = "at";
if (smh != null) {
ref = smh.getLocalString(
ArchiveClassesLoadableHelper.class.getName() + ".ref",
ref);
reference = smh.getLocalString(
ArchiveClassesLoadableHelper.class.getName() + ".reference",
reference);
}
StringTokenizer st = new StringTokenizer(referencingPath, File.separator);
Stack<String> referencingClassStack = new Stack<String>();
while(st.hasMoreTokens()) {
referencingClassStack.push(st.nextToken());
}
if(!referencingClassStack.isEmpty())
sb.append("\n\n"+ref);
while(!referencingClassStack.isEmpty()){
sb.append("\n\t").append(reference).append(" ");
sb.append(referencingClassStack.pop());
}
sb.append("\n\n");
}
return sb.toString();