class org.apache.isis.subdomains.excel.applib.service._ExcelConverter extends java.lang.Object
{
private static final java.lang.String XLSX_SUFFIX;
private static final java.util.function.Predicate VISIBLE_PROPERTIES;
private final org.apache.isis.core.metamodel.specloader.SpecificationLoader specificationLoader;
private final org.apache.isis.core.metamodel.objectmanager.ObjectManager objectManager;
private final org.apache.isis.applib.services.bookmark.BookmarkService bookmarkService;
private final org.apache.isis.applib.services.inject.ServiceInjector serviceInjector;
void <init>(org.apache.isis.core.metamodel.specloader.SpecificationLoader, org.apache.isis.core.metamodel.objectmanager.ObjectManager, org.apache.isis.applib.services.bookmark.BookmarkService, org.apache.isis.applib.services.inject.ServiceInjector)
{
org.apache.isis.core.metamodel.specloader.SpecificationLoader v;
org.apache.isis.applib.services.bookmark.BookmarkService v;
org.apache.isis.applib.services.inject.ServiceInjector v;
org.apache.isis.core.metamodel.objectmanager.ObjectManager v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: org.apache.isis.core.metamodel.specloader.SpecificationLoader;
v := @parameter: org.apache.isis.core.metamodel.objectmanager.ObjectManager;
v := @parameter: org.apache.isis.applib.services.bookmark.BookmarkService;
v := @parameter: org.apache.isis.applib.services.inject.ServiceInjector;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.core.metamodel.specloader.SpecificationLoader specificationLoader> = v;
v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.core.metamodel.objectmanager.ObjectManager objectManager> = v;
v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.applib.services.bookmark.BookmarkService bookmarkService> = v;
v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.applib.services.inject.ServiceInjector serviceInjector> = v;
return;
}
java.io.File appendSheet(java.util.List, org.apache.poi.xssf.usermodel.XSSFWorkbook) throws java.io.IOException
{
org.apache.poi.xssf.usermodel.XSSFWorkbook v;
java.util.stream.Collector v;
boolean v, v;
org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory v;
java.util.UUID v;
java.util.List v, v;
java.util.stream.Stream v, v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
java.lang.Throwable v;
java.lang.Object[] v;
org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec v;
java.util.function.Function v;
int v, v, v;
java.lang.String v, v, v, v, v;
java.util.Iterator v, v;
java.io.FileOutputStream v;
java.lang.IllegalArgumentException v, v;
java.io.File v;
java.lang.Class v;
java.lang.Object v, v, v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: java.util.List;
v := @parameter: org.apache.poi.xssf.usermodel.XSSFWorkbook;
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = staticinvoke <org.apache.isis.subdomains.excel.applib.service._ExcelConverter$lambda_appendSheet_0__1: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream map(java.util.function.Function)>(v);
v = staticinvoke <java.util.stream.Collectors: java.util.stream.Collector toSet()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object collect(java.util.stream.Collector)>(v);
v = interfaceinvoke v.<java.util.Set: int size()>();
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Sheet names must have distinct names");
throw v;
label:
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 30 goto label;
v = new java.lang.IllegalArgumentException;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Sheet name cannot exceed 30 characters (invalid name: \'%s\')", v);
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = class "Lorg/apache/isis/subdomains/excel/applib/service/_ExcelConverter;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <java.util.UUID: java.util.UUID randomUUID()>();
v = virtualinvoke v.<java.util.UUID: java.lang.String toString()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u.xlsx");
v = staticinvoke <java.io.File: java.io.File createTempFile(java.lang.String,java.lang.String)>(v, v);
v = new java.io.FileOutputStream;
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File)>(v);
label:
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetContent: org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec getSpec()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetContent: java.util.List getDomainObjects()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec: org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory getFactory()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec: java.lang.String getSheetName()>();
specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.poi.ss.usermodel.Sheet appendSheet(org.apache.poi.xssf.usermodel.XSSFWorkbook,java.util.List,org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory,java.lang.String)>(v, v, v, v);
goto label;
label:
virtualinvoke v.<org.apache.poi.xssf.usermodel.XSSFWorkbook: void write(java.io.OutputStream)>(v);
label:
virtualinvoke v.<java.io.FileOutputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
private org.apache.poi.ss.usermodel.Sheet appendSheet(org.apache.poi.xssf.usermodel.XSSFWorkbook, java.util.List, org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory, java.lang.String) throws java.io.IOException
{
org.apache.poi.xssf.usermodel.XSSFWorkbook v;
org.apache.poi.ss.usermodel.Cell v, v;
java.util.stream.Collector v;
org.apache.isis.core.metamodel.objectmanager.ObjectManager v;
boolean v, v, v, v, v;
org.apache.poi.ss.usermodel.Sheet v;
org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory v;
java.util.function.Predicate v;
java.util.List v, v;
java.util.stream.Stream v, v, v, v;
java.util.Optional v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
org.apache.isis.core.metamodel.specloader.SpecificationLoader v;
java.util.function.Function v;
java.util.ArrayList v, v;
int v, v, v, v;
java.lang.String v, v;
java.util.Iterator v, v, v, v;
java.util.function.Consumer v, v;
org.apache.poi.ss.usermodel.Row v, v;
java.lang.Class v, v;
java.lang.Object v, v, v, v, v;
org.apache.isis.subdomains.excel.applib.service._CellMarshaller v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter$RowFactory v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: org.apache.poi.xssf.usermodel.XSSFWorkbook;
v := @parameter: java.util.List;
v := @parameter: org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory;
v := @parameter: java.lang.String;
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.core.metamodel.objectmanager.ObjectManager objectManager>;
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <org.apache.isis.subdomains.excel.applib.service._ExcelConverter$adapt__2: java.util.function.Function bootstrap$(org.apache.isis.core.metamodel.objectmanager.ObjectManager)>(v);
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream map(java.util.function.Function)>(v);
v = staticinvoke <java.util.stream.Collectors: java.util.stream.Collector toList()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object collect(java.util.stream.Collector)>(v);
v = staticinvoke <org.apache.isis.commons.internal.collections._Lists: java.util.ArrayList newArrayList()>();
v = v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.core.metamodel.specloader.SpecificationLoader specificationLoader>;
v = interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory: java.lang.Class getCls()>();
v = interfaceinvoke v.<org.apache.isis.core.metamodel.specloader.SpecificationLoader: java.util.Optional specForType(java.lang.Class)>(v);
v = staticinvoke <org.apache.isis.subdomains.excel.applib.service._ExcelConverter$lambda_appendSheet_1__3: java.util.function.Consumer bootstrap$(java.util.List)>(v);
virtualinvoke v.<java.util.Optional: void ifPresent(java.util.function.Consumer)>(v);
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory: java.lang.Class getCls()>();
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List fieldsAnnotatedWith(java.lang.Class,java.lang.Class)>(v, class "Lorg/apache/isis/subdomains/excel/applib/dom/HyperLink;");
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = staticinvoke <org.apache.isis.subdomains.excel.applib.service._ExcelConverter$lambda_appendSheet_2__4: java.util.function.Predicate bootstrap$(java.lang.reflect.Field)>(v);
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream filter(java.util.function.Predicate)>(v);
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <org.apache.isis.subdomains.excel.applib.service._ExcelConverter$add__5: java.util.function.Consumer bootstrap$(java.util.List)>(v);
interfaceinvoke v.<java.util.stream.Stream: void forEach(java.util.function.Consumer)>(v);
goto label;
label:
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Workbook: org.apache.poi.ss.usermodel.Sheet createSheet(java.lang.String)>(v);
v = new org.apache.isis.subdomains.excel.applib.service._ExcelConverter$RowFactory;
specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$RowFactory: void <init>(org.apache.poi.ss.usermodel.Sheet)>(v);
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$RowFactory: org.apache.poi.ss.usermodel.Row newRow()>();
v = 0;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = v;
v = v + 1;
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Row: org.apache.poi.ss.usermodel.Cell createCell(int)>(v);
v = interfaceinvoke v.<org.apache.isis.core.metamodel.spec.feature.OneToOneAssociation: java.lang.String getCanonicalFriendlyName()>();
interfaceinvoke v.<org.apache.poi.ss.usermodel.Cell: void setCellValue(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.subdomains.excel.applib.service._CellMarshaller newCellMarshaller(org.apache.poi.ss.usermodel.Workbook)>(v);
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$RowFactory: org.apache.poi.ss.usermodel.Row newRow()>();
v = 0;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = v;
v = v + 1;
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Row: org.apache.poi.ss.usermodel.Cell createCell(int)>(v);
v = interfaceinvoke v.<java.util.List: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._CellMarshaller: void setCellValueForHyperlink(org.apache.isis.core.metamodel.spec.ManagedObject,org.apache.isis.core.metamodel.spec.feature.OneToOneAssociation,org.apache.poi.ss.usermodel.Cell)>(v, v, v);
goto label;
label:
virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._CellMarshaller: void setCellValue(org.apache.isis.core.metamodel.spec.ManagedObject,org.apache.isis.core.metamodel.spec.feature.OneToOneAssociation,org.apache.poi.ss.usermodel.Cell)>(v, v, v);
goto label;
label:
interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: void createFreezePane(int,int)>(0, 1);
return v;
}
java.io.File appendPivotSheet(java.util.List) throws java.io.IOException
{
org.apache.poi.xssf.usermodel.XSSFWorkbook v;
java.util.stream.Collector v;
boolean v, v;
org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory v;
java.util.function.Predicate v;
java.util.UUID v;
java.util.List v, v;
java.util.stream.Stream v, v, v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
java.lang.Throwable v, v;
java.lang.Object[] v;
org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec v;
java.util.function.Function v;
int v, v, v;
java.lang.String v, v, v, v, v;
java.util.Iterator v, v;
java.io.FileOutputStream v;
java.lang.IllegalArgumentException v, v;
java.io.File v;
java.lang.Class v;
java.lang.Object v, v, v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: java.util.List;
v = staticinvoke <org.apache.isis.commons.internal.base._NullSafe: java.util.stream.Stream stream(java.util.Collection)>(v);
v = staticinvoke <org.apache.isis.subdomains.excel.applib.service._ExcelConverter$lambda_appendPivotSheet_3__6: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream map(java.util.function.Function)>(v);
v = staticinvoke <org.apache.isis.subdomains.excel.applib.service._ExcelConverter$isNotEmpty__7: java.util.function.Predicate bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream filter(java.util.function.Predicate)>(v);
v = staticinvoke <org.apache.isis.commons.internal.collections._Sets: java.util.stream.Collector toUnmodifiableSorted()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object collect(java.util.stream.Collector)>(v);
v = interfaceinvoke v.<java.util.SortedSet: int size()>();
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Sheet names must have distinct names and cannot be empty");
throw v;
label:
v = interfaceinvoke v.<java.util.SortedSet: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 30 goto label;
v = new java.lang.IllegalArgumentException;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Sheet name cannot exceed 30 characters (invalid name: \'%s\')", v);
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new org.apache.poi.xssf.usermodel.XSSFWorkbook;
specialinvoke v.<org.apache.poi.xssf.usermodel.XSSFWorkbook: void <init>()>();
label:
v = class "Lorg/apache/isis/subdomains/excel/applib/service/_ExcelConverter;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <java.util.UUID: java.util.UUID randomUUID()>();
v = virtualinvoke v.<java.util.UUID: java.lang.String toString()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u.xlsx");
v = staticinvoke <java.io.File: java.io.File createTempFile(java.lang.String,java.lang.String)>(v, v);
v = new java.io.FileOutputStream;
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File)>(v);
label:
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetContent: org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec getSpec()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetContent: java.util.List getDomainObjects()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec: org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory getFactory()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec: java.lang.String getSheetName()>();
specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: void appendPivotSheet(org.apache.poi.xssf.usermodel.XSSFWorkbook,java.util.List,org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory,java.lang.String)>(v, v, v, v);
goto label;
label:
virtualinvoke v.<org.apache.poi.xssf.usermodel.XSSFWorkbook: void write(java.io.OutputStream)>(v);
label:
virtualinvoke v.<java.io.FileOutputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
virtualinvoke v.<org.apache.poi.xssf.usermodel.XSSFWorkbook: void close()>();
return v;
label:
v := @caughtexception;
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void appendPivotSheet(org.apache.poi.xssf.usermodel.XSSFWorkbook, java.util.List, org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory, java.lang.String) throws java.io.IOException
{
java.lang.Integer v;
org.apache.poi.xssf.usermodel.XSSFWorkbook v;
boolean v, v;
org.apache.poi.ss.usermodel.Sheet v, v;
org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory v;
org.apache.isis.subdomains.excel.applib.util.SheetPivoter v;
java.util.List v, v;
java.util.Optional v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
org.apache.isis.core.metamodel.specloader.SpecificationLoader v;
org.apache.isis.subdomains.excel.applib.dom.AggregationType v;
java.util.ArrayList v, v, v, v;
int v, v, v;
java.lang.String v, v, v, v;
java.util.Iterator v;
java.util.function.Consumer v;
org.apache.poi.ss.usermodel.Row v, v, v;
java.lang.Class v, v, v;
java.lang.Object v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: org.apache.poi.xssf.usermodel.XSSFWorkbook;
v := @parameter: java.util.List;
v := @parameter: org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory;
v := @parameter: java.lang.String;
v = staticinvoke <org.apache.isis.commons.internal.collections._Lists: java.util.ArrayList newArrayList()>();
v = v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.core.metamodel.specloader.SpecificationLoader specificationLoader>;
v = interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory: java.lang.Class getCls()>();
v = interfaceinvoke v.<org.apache.isis.core.metamodel.specloader.SpecificationLoader: java.util.Optional specForType(java.lang.Class)>(v);
v = staticinvoke <org.apache.isis.subdomains.excel.applib.service._ExcelConverter$lambda_appendPivotSheet_4__8: java.util.function.Consumer bootstrap$(java.util.List)>(v);
virtualinvoke v.<java.util.Optional: void ifPresent(java.util.function.Consumer)>(v);
v = interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory: java.lang.Class getCls()>();
specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: void validateAnnotations(java.util.List,java.lang.Class)>(v, v);
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory: java.lang.Class getCls()>();
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List getAnnotationAndOrderFrom(java.util.List,java.lang.Class)>(v, v);
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType: java.lang.String 'annotation'>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType: java.lang.Integer order>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType: org.apache.isis.subdomains.excel.applib.dom.AggregationType type>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Workbook: org.apache.poi.ss.usermodel.Sheet createSheet(java.lang.String)>(v);
v = "source for ";
v = virtualinvoke v.<java.lang.String: java.lang.String concat(java.lang.String)>(v);
v = staticinvoke <org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec: boolean isTooLong(java.lang.String)>(v);
if v == 0 goto label;
v = staticinvoke <org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec: java.lang.String trim(java.lang.String)>(v);
label:
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.poi.ss.usermodel.Sheet appendSheet(org.apache.poi.xssf.usermodel.XSSFWorkbook,java.util.List,org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory,java.lang.String)>(v, v, v, v);
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: int getLastRowNum()>();
interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: void shiftRows(int,int,int)>(0, v, 3);
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: org.apache.poi.ss.usermodel.Row createRow(int)>(0);
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: org.apache.poi.ss.usermodel.Row createRow(int)>(1);
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: org.apache.poi.ss.usermodel.Row createRow(int)>(2);
staticinvoke <org.apache.isis.subdomains.excel.applib.util.PivotUtils: void createAnnotationRow(org.apache.poi.ss.usermodel.Row,java.util.List)>(v, v);
staticinvoke <org.apache.isis.subdomains.excel.applib.util.PivotUtils: void createOrderRow(org.apache.poi.ss.usermodel.Row,java.util.List)>(v, v);
staticinvoke <org.apache.isis.subdomains.excel.applib.util.PivotUtils: void createTypeRow(org.apache.poi.ss.usermodel.Row,java.util.List)>(v, v);
v = new org.apache.isis.subdomains.excel.applib.util.SheetPivoter;
specialinvoke v.<org.apache.isis.subdomains.excel.applib.util.SheetPivoter: void <init>()>();
virtualinvoke v.<org.apache.isis.subdomains.excel.applib.util.SheetPivoter: void pivot(org.apache.poi.ss.usermodel.Sheet,org.apache.poi.ss.usermodel.Sheet)>(v, v);
interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: void removeRow(org.apache.poi.ss.usermodel.Row)>(v);
interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: void removeRow(org.apache.poi.ss.usermodel.Row)>(v);
interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: void removeRow(org.apache.poi.ss.usermodel.Row)>(v);
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: int getLastRowNum()>();
v = (int) -3;
interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: void shiftRows(int,int,int)>(3, v, v);
return;
}
private void validateAnnotations(java.util.List, java.lang.Class) throws java.lang.IllegalArgumentException
{
java.lang.IllegalArgumentException v, v, v, v;
java.util.List v, v, v, v, v;
int v, v, v, v;
java.lang.Class v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: java.util.List;
v := @parameter: java.lang.Class;
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List fieldsAnnotatedWith(java.lang.Class,java.lang.Class)>(v, class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotRow;");
v = interfaceinvoke v.<java.util.List: int size()>();
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("No annotation for row found");
throw v;
label:
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List fieldsAnnotatedWith(java.lang.Class,java.lang.Class)>(v, class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotRow;");
v = interfaceinvoke v.<java.util.List: int size()>();
if v <= 1 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Only one annotation for row allowed");
throw v;
label:
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List fieldsAnnotatedWith(java.lang.Class,java.lang.Class)>(v, class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotColumn;");
v = interfaceinvoke v.<java.util.List: int size()>();
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("No annotation for column found");
throw v;
label:
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List fieldsAnnotatedWith(java.lang.Class,java.lang.Class)>(v, class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotValue;");
v = interfaceinvoke v.<java.util.List: int size()>();
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("No annotation for value found");
throw v;
label:
return;
}
private java.util.List getAnnotationAndOrderFrom(java.util.List, java.lang.Class)
{
java.lang.Integer v, v, v, v, v;
boolean v, v, v, v, v, v, v, v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType v, v, v, v, v, v;
java.util.List v, v, v, v, v;
java.lang.'annotation'.Annotation v, v, v, v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
org.apache.isis.subdomains.excel.applib.dom.AggregationType v;
java.util.ArrayList v;
int v, v, v;
java.lang.String v, v, v, v, v, v, v, v;
java.util.Iterator v, v, v, v;
java.lang.Class v;
java.lang.Object v, v, v, v, v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: java.util.List;
v := @parameter: java.lang.Class;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = null;
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List fieldsAnnotatedWith(java.lang.Class,java.lang.Class)>(v, class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotRow;");
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.String getName()>();
v = interfaceinvoke v.<org.apache.isis.core.metamodel.spec.feature.ObjectAssociation: java.lang.String getId()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = new org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(0);
specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType: void <init>(org.apache.isis.subdomains.excel.applib.service._ExcelConverter,java.lang.String,java.lang.Integer,org.apache.isis.subdomains.excel.applib.dom.AggregationType)>(v, "row", v, null);
v = v;
label:
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List fieldsAnnotatedWith(java.lang.Class,java.lang.Class)>(v, class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotColumn;");
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.String getName()>();
v = interfaceinvoke v.<org.apache.isis.core.metamodel.spec.feature.ObjectAssociation: java.lang.String getId()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = new org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType;
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.'annotation'.Annotation getAnnotation(java.lang.Class)>(class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotColumn;");
v = interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.PivotColumn: int order()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType: void <init>(org.apache.isis.subdomains.excel.applib.service._ExcelConverter,java.lang.String,java.lang.Integer,org.apache.isis.subdomains.excel.applib.dom.AggregationType)>(v, "column", v, null);
v = v;
goto label;
label:
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List fieldsAnnotatedWith(java.lang.Class,java.lang.Class)>(v, class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotValue;");
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.String getName()>();
v = interfaceinvoke v.<org.apache.isis.core.metamodel.spec.feature.ObjectAssociation: java.lang.String getId()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = new org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType;
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.'annotation'.Annotation getAnnotation(java.lang.Class)>(class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotValue;");
v = interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.PivotValue: int order()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.'annotation'.Annotation getAnnotation(java.lang.Class)>(class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotValue;");
v = interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.PivotValue: org.apache.isis.subdomains.excel.applib.dom.AggregationType type()>();
specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType: void <init>(org.apache.isis.subdomains.excel.applib.service._ExcelConverter,java.lang.String,java.lang.Integer,org.apache.isis.subdomains.excel.applib.dom.AggregationType)>(v, "value", v, v);
v = v;
goto label;
label:
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List fieldsAnnotatedWith(java.lang.Class,java.lang.Class)>(v, class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotDecoration;");
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.String getName()>();
v = interfaceinvoke v.<org.apache.isis.core.metamodel.spec.feature.ObjectAssociation: java.lang.String getId()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = new org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType;
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.'annotation'.Annotation getAnnotation(java.lang.Class)>(class "Lorg/apache/isis/subdomains/excel/applib/dom/PivotDecoration;");
v = interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.PivotDecoration: int order()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType: void <init>(org.apache.isis.subdomains.excel.applib.service._ExcelConverter,java.lang.String,java.lang.Integer,org.apache.isis.subdomains.excel.applib.dom.AggregationType)>(v, "deco", v, null);
v = v;
goto label;
label:
if v != null goto label;
v = new org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(0);
specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$AnnotationOrderAndType: void <init>(org.apache.isis.subdomains.excel.applib.service._ExcelConverter,java.lang.String,java.lang.Integer,org.apache.isis.subdomains.excel.applib.dom.AggregationType)>(v, "skip", v, null);
v = v;
label:
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
return v;
}
private java.util.List fieldsAnnotatedWith(java.lang.Class, java.lang.Class)
{
java.lang.reflect.Field v;
java.util.ArrayList v;
java.lang.reflect.Field[] v;
int v, v;
java.lang.Class v, v;
boolean v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: java.lang.Class;
v := @parameter: java.lang.Class;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Field[] getDeclaredFields()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.reflect.Field: boolean isAnnotationPresent(java.lang.Class)>(v);
if v == 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = v + 1;
goto label;
label:
return v;
}
java.util.List fromBytes(java.util.List, byte[]) throws java.io.IOException, org.apache.poi.openxml4j.exceptions.InvalidFormatException
{
byte[] v;
java.util.Iterator v;
java.util.ArrayList v;
java.util.List v, v;
java.lang.Object v;
boolean v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: java.util.List;
v := @parameter: byte[];
v = staticinvoke <org.apache.isis.commons.internal.collections._Lists: java.util.ArrayList newArrayList()>();
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List fromBytes(byte[],org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec)>(v, v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
return v;
}
java.util.List fromBytes(byte[], org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec) throws java.io.IOException, org.apache.poi.openxml4j.exceptions.InvalidFormatException
{
java.lang.Throwable v;
byte[] v;
java.util.List v;
org.apache.poi.ss.usermodel.Workbook v;
java.io.ByteArrayInputStream v;
org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: byte[];
v := @parameter: org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec;
v = new java.io.ByteArrayInputStream;
specialinvoke v.<java.io.ByteArrayInputStream: void <init>(byte[])>(v);
label:
v = staticinvoke <org.apache.poi.ss.usermodel.WorkbookFactory: org.apache.poi.ss.usermodel.Workbook create(java.io.InputStream)>(v);
v = specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List fromWorkbook(org.apache.poi.ss.usermodel.Workbook,org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec)>(v, v);
label:
virtualinvoke v.<java.io.ByteArrayInputStream: void close()>();
return v;
label:
v := @caughtexception;
throw v;
catch java.lang.Throwable from label to label with label;
}
private java.util.List fromWorkbook(org.apache.poi.ss.usermodel.Workbook, org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec)
{
java.lang.Integer v, v, v, v, v;
org.apache.poi.ss.usermodel.Sheet v;
org.apache.isis.core.metamodel.spec.ObjectSpecification v;
java.lang.Exception v, v;
org.apache.isis.core.metamodel.spec.feature.OneToOneAssociation v, v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
org.apache.isis.core.metamodel.specloader.SpecificationLoader v;
java.lang.Object[] v, v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter$Property v;
org.apache.isis.applib.services.inject.ServiceInjector v;
org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec v;
java.util.ArrayList v;
org.apache.isis.core.metamodel.consent.InteractionInitiatedBy v;
java.lang.String v, v, v, v, v, v;
org.apache.isis.subdomains.excel.applib.dom.ExcelService$Exception v, v;
org.apache.poi.ss.usermodel.Workbook v;
org.apache.isis.subdomains.excel.applib.service._CellMarshaller v;
org.apache.isis.subdomains.excel.applib.util.Mode v;
int[] v, v;
org.apache.isis.core.metamodel.objectmanager.ObjectManager v, v;
boolean v, v, v, v, v, v;
org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory v;
org.apache.isis.core.metamodel.spec.ManagedObject v, v;
java.util.Optional v;
org.apache.poi.ss.usermodel.CellType v, v;
java.util.HashMap v;
int v, v, v, v, v, v, v, v, v;
java.util.Iterator v, v, v;
java.lang.Class v, v, v;
java.lang.Object v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: org.apache.poi.ss.usermodel.Workbook;
v := @parameter: org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec;
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec: org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory getFactory()>();
v = v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.applib.services.inject.ServiceInjector serviceInjector>;
interfaceinvoke v.<org.apache.isis.applib.services.inject.ServiceInjector: java.lang.Object injectServicesInto(java.lang.Object)>(v);
v = interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory: java.lang.Class getCls()>();
v = staticinvoke <org.apache.isis.commons.internal.base._Casts: java.lang.Object uncheckedCast(java.lang.Object)>(v);
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec: java.lang.String getSheetName()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec: org.apache.isis.subdomains.excel.applib.util.Mode getMode()>();
v = staticinvoke <org.apache.isis.commons.internal.collections._Lists: java.util.ArrayList newArrayList()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.subdomains.excel.applib.service._CellMarshaller newCellMarshaller(org.apache.poi.ss.usermodel.Workbook)>(v);
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.poi.ss.usermodel.Sheet lookupSheet(java.lang.Class,java.lang.String,org.apache.poi.ss.usermodel.Workbook)>(v, v, v);
v = 1;
v = staticinvoke <org.apache.isis.commons.internal.collections._Maps: java.util.HashMap newHashMap()>();
v = v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.core.metamodel.specloader.SpecificationLoader specificationLoader>;
v = interfaceinvoke v.<org.apache.isis.core.metamodel.specloader.SpecificationLoader: java.util.Optional specForType(java.lang.Class)>(v);
v = virtualinvoke v.<java.util.Optional: java.lang.Object orElse(java.lang.Object)>(null);
v = null;
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Sheet: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Row: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
label:
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Cell: org.apache.poi.ss.usermodel.CellType getCellType()>();
v = <org.apache.poi.ss.usermodel.CellType: org.apache.poi.ss.usermodel.CellType BLANK>;
if v == v goto label;
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Cell: int getColumnIndex()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._CellMarshaller: java.lang.String getStringCellValue(org.apache.poi.ss.usermodel.Cell)>(v);
v = staticinvoke <org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.core.metamodel.spec.feature.OneToOneAssociation getAssociation(org.apache.isis.core.metamodel.spec.ObjectSpecification,java.lang.String)>(v, v);
if v == null goto label;
v = interfaceinvoke v.<org.apache.isis.core.metamodel.spec.feature.OneToOneAssociation: org.apache.isis.core.metamodel.spec.ObjectSpecification getElementType()>();
v = interfaceinvoke v.<org.apache.isis.core.metamodel.spec.ObjectSpecification: java.lang.Class getCorrespondingClass()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = new org.apache.isis.subdomains.excel.applib.service._ExcelConverter$Property;
specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$Property: void <init>(java.lang.String,org.apache.isis.core.metamodel.spec.feature.OneToOneAssociation,java.lang.Class)>(v, v, v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.isis.subdomains.excel.applib.service._ExcelConverter$1: int[] $SwitchMap$org$apache$isis$subdomains$excel$applib$util$Mode>;
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.util.Mode: int ordinal()>();
v = v[v];
lookupswitch(v)
{
case 1: goto label;
default: goto label;
};
label:
v = new org.apache.isis.subdomains.excel.applib.dom.ExcelService$Exception;
v = newarray (java.lang.Object)[2];
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Row: int getRowNum()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Error processing Excel row nr. %d. Message: %s", v);
specialinvoke v.<org.apache.isis.subdomains.excel.applib.dom.ExcelService$Exception: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v = 0;
goto label;
label:
v = null;
v = null;
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Row: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
label:
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Cell: int getColumnIndex()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter$Property: org.apache.isis.core.metamodel.spec.feature.OneToOneAssociation getOneToOneAssociation()>();
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._CellMarshaller: java.lang.Object getCellValue(org.apache.poi.ss.usermodel.Cell,org.apache.isis.core.metamodel.spec.feature.OneToOneAssociation)>(v, v);
if v == null goto label;
if v != null goto label;
v = interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec$RowFactory: java.lang.Object create()>();
v = staticinvoke <org.apache.isis.commons.internal.base._Casts: java.lang.Object uncheckedCast(java.lang.Object)>(v);
v = class "Lorg/apache/isis/subdomains/excel/applib/dom/ExcelMetaDataEnabled;";
v = virtualinvoke v.<java.lang.Class: boolean isAssignableFrom(java.lang.Class)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Row: int getRowNum()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.ExcelMetaDataEnabled: void setExcelRowNumber(java.lang.Integer)>(v);
interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.ExcelMetaDataEnabled: void setExcelSheetName(java.lang.String)>(v);
v = staticinvoke <org.apache.isis.commons.internal.base._Casts: java.lang.Object uncheckedCast(java.lang.Object)>(v);
label:
v = v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.core.metamodel.objectmanager.ObjectManager objectManager>;
v = interfaceinvoke v.<org.apache.isis.core.metamodel.objectmanager.ObjectManager: org.apache.isis.core.metamodel.spec.ManagedObject adapt(java.lang.Object)>(v);
label:
v = v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.core.metamodel.objectmanager.ObjectManager objectManager>;
v = interfaceinvoke v.<org.apache.isis.core.metamodel.objectmanager.ObjectManager: org.apache.isis.core.metamodel.spec.ManagedObject adapt(java.lang.Object)>(v);
v = <org.apache.isis.core.metamodel.consent.InteractionInitiatedBy: org.apache.isis.core.metamodel.consent.InteractionInitiatedBy USER>;
interfaceinvoke v.<org.apache.isis.core.metamodel.spec.feature.OneToOneAssociation: org.apache.isis.core.metamodel.spec.ManagedObject set(org.apache.isis.core.metamodel.spec.ManagedObject,org.apache.isis.core.metamodel.spec.ManagedObject,org.apache.isis.core.metamodel.consent.InteractionInitiatedBy)>(v, v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.isis.subdomains.excel.applib.service._ExcelConverter$1: int[] $SwitchMap$org$apache$isis$subdomains$excel$applib$util$Mode>;
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.util.Mode: int ordinal()>();
v = v[v];
lookupswitch(v)
{
case 1: goto label;
default: goto label;
};
label:
v = new org.apache.isis.subdomains.excel.applib.dom.ExcelService$Exception;
v = newarray (java.lang.Object)[2];
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Row: int getRowNum()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Error processing Excel row nr. %d. Message: %s", v);
specialinvoke v.<org.apache.isis.subdomains.excel.applib.dom.ExcelService$Exception: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
if v == null goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v instanceof org.apache.isis.subdomains.excel.applib.dom.RowHandler;
if v == 0 goto label;
v = staticinvoke <org.apache.isis.commons.internal.base._Casts: java.lang.Object uncheckedCast(java.lang.Object)>(v);
interfaceinvoke v.<org.apache.isis.subdomains.excel.applib.dom.RowHandler: void handleRow(org.apache.isis.subdomains.excel.applib.dom.RowHandler)>(v);
label:
v = v;
goto label;
label:
return v;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
protected org.apache.poi.ss.usermodel.Sheet lookupSheet(java.lang.Class, java.lang.String, org.apache.poi.ss.usermodel.Workbook)
{
org.apache.poi.ss.usermodel.Sheet v;
java.util.List v;
org.apache.poi.ss.usermodel.Workbook v;
java.lang.Class v;
java.lang.String v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: java.lang.Class;
v := @parameter: java.lang.String;
v := @parameter: org.apache.poi.ss.usermodel.Workbook;
v = staticinvoke <org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.List determineCandidateSheetNames(java.lang.String,java.lang.Class)>(v, v);
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.poi.ss.usermodel.Sheet lookupSheet(org.apache.poi.ss.usermodel.Workbook,java.util.List)>(v, v);
return v;
}
private static java.util.List determineCandidateSheetNames(java.lang.String, java.lang.Class)
{
java.lang.Class v;
java.lang.String v, v, v;
boolean v;
java.util.ArrayList v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Class;
v = staticinvoke <org.apache.isis.commons.internal.collections._Lists: java.util.ArrayList newArrayList()>();
if v == null goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = staticinvoke <org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec: boolean hasSuffix(java.lang.String)>(v);
if v == 0 goto label;
v = staticinvoke <org.apache.isis.subdomains.excel.applib.dom.WorksheetSpec: java.lang.String prefix(java.lang.String)>(v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
return v;
}
protected org.apache.poi.ss.usermodel.Sheet lookupSheet(org.apache.poi.ss.usermodel.Workbook, java.util.List)
{
org.apache.poi.ss.usermodel.Sheet v;
java.lang.Object[] v;
java.util.Iterator v;
java.lang.IllegalArgumentException v;
java.util.List v;
org.apache.poi.ss.usermodel.Workbook v;
java.lang.Object v;
java.lang.String v;
boolean v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: org.apache.poi.ss.usermodel.Workbook;
v := @parameter: java.util.List;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Workbook: org.apache.poi.ss.usermodel.Sheet getSheet(java.lang.String)>(v);
if v == null goto label;
return v;
label:
v = new java.lang.IllegalArgumentException;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Could not locate sheet named any of: \'%s\'", v);
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
}
private static org.apache.isis.core.metamodel.spec.feature.OneToOneAssociation getAssociation(org.apache.isis.core.metamodel.spec.ObjectSpecification, java.lang.String)
{
java.util.function.Predicate v;
org.apache.isis.core.metamodel.spec.feature.MixedIn v;
org.apache.isis.core.metamodel.spec.ObjectSpecification v;
java.util.stream.Stream v, v;
java.util.Optional v;
java.lang.Object v;
java.lang.String v;
v := @parameter: org.apache.isis.core.metamodel.spec.ObjectSpecification;
v := @parameter: java.lang.String;
if v != null goto label;
return null;
label:
v = <org.apache.isis.core.metamodel.spec.feature.MixedIn: org.apache.isis.core.metamodel.spec.feature.MixedIn INCLUDED>;
v = interfaceinvoke v.<org.apache.isis.core.metamodel.spec.ObjectSpecification: java.util.stream.Stream streamProperties(org.apache.isis.core.metamodel.spec.feature.MixedIn)>(v);
v = staticinvoke <org.apache.isis.subdomains.excel.applib.service._ExcelConverter$lambda_getAssociation_5__9: java.util.function.Predicate bootstrap$(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream filter(java.util.function.Predicate)>(v);
v = interfaceinvoke v.<java.util.stream.Stream: java.util.Optional findFirst()>();
v = virtualinvoke v.<java.util.Optional: java.lang.Object orElse(java.lang.Object)>(null);
return v;
}
protected org.apache.isis.subdomains.excel.applib.service._CellMarshaller newCellMarshaller(org.apache.poi.ss.usermodel.Workbook)
{
org.apache.poi.ss.usermodel.Workbook v;
org.apache.isis.applib.services.bookmark.BookmarkService v;
org.apache.isis.subdomains.excel.applib.service._CellMarshaller v;
org.apache.poi.ss.usermodel.CellStyle v, v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: org.apache.poi.ss.usermodel.Workbook;
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.poi.ss.usermodel.CellStyle createDateFormatCellStyle(org.apache.poi.ss.usermodel.Workbook)>(v);
v = virtualinvoke v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.poi.ss.usermodel.CellStyle defaultCellStyle(org.apache.poi.ss.usermodel.Workbook)>(v);
v = new org.apache.isis.subdomains.excel.applib.service._CellMarshaller;
v = v.<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: org.apache.isis.applib.services.bookmark.BookmarkService bookmarkService>;
specialinvoke v.<org.apache.isis.subdomains.excel.applib.service._CellMarshaller: void <init>(org.apache.isis.applib.services.bookmark.BookmarkService,org.apache.poi.ss.usermodel.CellStyle,org.apache.poi.ss.usermodel.CellStyle)>(v, v, v);
return v;
}
protected org.apache.poi.ss.usermodel.CellStyle createDateFormatCellStyle(org.apache.poi.ss.usermodel.Workbook)
{
org.apache.poi.ss.usermodel.Workbook v;
short v;
org.apache.poi.ss.usermodel.VerticalAlignment v;
org.apache.poi.ss.usermodel.CreationHelper v;
org.apache.poi.ss.usermodel.DataFormat v;
org.apache.poi.ss.usermodel.CellStyle v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: org.apache.poi.ss.usermodel.Workbook;
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Workbook: org.apache.poi.ss.usermodel.CreationHelper getCreationHelper()>();
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.CreationHelper: org.apache.poi.ss.usermodel.DataFormat createDataFormat()>();
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.DataFormat: short getFormat(java.lang.String)>("yyyy-mm-dd");
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Workbook: org.apache.poi.ss.usermodel.CellStyle createCellStyle()>();
interfaceinvoke v.<org.apache.poi.ss.usermodel.CellStyle: void setDataFormat(short)>(v);
v = <org.apache.poi.ss.usermodel.VerticalAlignment: org.apache.poi.ss.usermodel.VerticalAlignment TOP>;
interfaceinvoke v.<org.apache.poi.ss.usermodel.CellStyle: void setVerticalAlignment(org.apache.poi.ss.usermodel.VerticalAlignment)>(v);
return v;
}
protected org.apache.poi.ss.usermodel.CellStyle defaultCellStyle(org.apache.poi.ss.usermodel.Workbook)
{
org.apache.poi.ss.usermodel.Workbook v;
org.apache.poi.ss.usermodel.VerticalAlignment v;
org.apache.poi.ss.usermodel.CellStyle v;
org.apache.isis.subdomains.excel.applib.service._ExcelConverter v;
v := @this: org.apache.isis.subdomains.excel.applib.service._ExcelConverter;
v := @parameter: org.apache.poi.ss.usermodel.Workbook;
v = interfaceinvoke v.<org.apache.poi.ss.usermodel.Workbook: org.apache.poi.ss.usermodel.CellStyle createCellStyle()>();
v = <org.apache.poi.ss.usermodel.VerticalAlignment: org.apache.poi.ss.usermodel.VerticalAlignment TOP>;
interfaceinvoke v.<org.apache.poi.ss.usermodel.CellStyle: void setVerticalAlignment(org.apache.poi.ss.usermodel.VerticalAlignment)>(v);
return v;
}
static void <clinit>()
{
java.util.function.Predicate v, v, v;
org.apache.isis.applib.'annotation'.Where v;
v = <org.apache.isis.core.metamodel.spec.feature.ObjectAssociation$Predicates: java.util.function.Predicate PROPERTIES>;
v = <org.apache.isis.applib.'annotation'.Where: org.apache.isis.applib.'annotation'.Where STANDALONE_TABLES>;
v = staticinvoke <org.apache.isis.core.metamodel.spec.feature.ObjectAssociation$Predicates: java.util.function.Predicate staticallyVisible(org.apache.isis.applib.'annotation'.Where)>(v);
v = interfaceinvoke v.<java.util.function.Predicate: java.util.function.Predicate and(java.util.function.Predicate)>(v);
<org.apache.isis.subdomains.excel.applib.service._ExcelConverter: java.util.function.Predicate VISIBLE_PROPERTIES> = v;
return;
}
}