/******************************************************************************* * Copyright 2012 University of Southern California * * 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. * * This code was developed by the Information Integration Group as part * of the Karma project at the Information Sciences Institute of the * University of Southern California. For more information, publications, * and related projects, please see: http://www.isi.edu/integration ******************************************************************************/ package edu.isi.karma.controller.command.service; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import org.apache.log4j.Logger; import edu.isi.karma.rep.HNode; import edu.isi.karma.rep.HTable; import edu.isi.karma.rep.Node; import edu.isi.karma.rep.RepFactory; import edu.isi.karma.rep.Row; import edu.isi.karma.rep.Worksheet; import edu.isi.karma.rep.sources.Attribute; import edu.isi.karma.rep.sources.Table; public class ServiceTableUtil { static Logger logger = Logger.getLogger(ServiceTableUtil.class); public static void populateEmptyWorksheet(Table table, Worksheet worksheet, RepFactory factory) { logger.info("Populating an empty worksheet with the service data ..."); List<String> hNodeIdList = new ArrayList<String>(); hNodeIdList = addHeaders(table.getHeaders(), worksheet, factory); edu.isi.karma.rep.Table dataTable = worksheet.getDataTable(); addRows(table.getValues(), worksheet, factory, hNodeIdList, dataTable); } public static void populateWorksheet(Table table, Worksheet worksheet, RepFactory factory) { logger.info("Populating existing worksheet with the service data ..."); List<String> oldHNodeIdList = new ArrayList<String>(worksheet.getHeaders().getHNodeIds()); List<String> hNodeIdList = new ArrayList<String>(); hNodeIdList = addHeaders(table.getHeaders(), worksheet, factory); edu.isi.karma.rep.Table dataTable = worksheet.getDataTable(); updateRows(table.getValues(), table.getRowIds(), worksheet, factory, oldHNodeIdList, hNodeIdList, dataTable); } private static List<String> addHeaders(List<Attribute> tableHeader, Worksheet worksheet, RepFactory factory) { HTable headers = worksheet.getHeaders(); List<String> headersList = new ArrayList<String>(); for (int i = 0; i < tableHeader.size(); i++) { Attribute att = tableHeader.get(i); HNode hNode = headers.addHNode(att.getName(), worksheet, factory); headersList.add(hNode.getId()); // very important // update the hNodeId of the input/output attributes att.sethNodeId(hNode.getId()); } return headersList; } private static void addRows(List<List<String>> tableValues, Worksheet worksheet, RepFactory factory, List<String> hNodeIdList, edu.isi.karma.rep.Table dataTable) { for (List<String> rowValues : tableValues) { if (rowValues == null || rowValues.size() == 0) continue; Row row = dataTable.addRow(factory); for (int i = 0; i < rowValues.size(); i++) row.setValue(hNodeIdList.get(i), rowValues.get(i), factory); } } private static void updateRows(List<List<String>> tableValues, List<String> tableRowIds, Worksheet worksheet, RepFactory factory, List<String> oldHNodeIdList, List<String> hNodeIdList, edu.isi.karma.rep.Table dataTable) { int rowsCount = dataTable.getNumRows(); List<Row> oldRows = dataTable.getRows(0, rowsCount); List<HashMap<String, String>> oldRowValues = new ArrayList<HashMap<String,String>>(); List<String> oldRowIds = new ArrayList<String>(); for (Row r : oldRows) { HashMap<String, String> vals = new HashMap<String, String>(); for (Node n : r.getNodes()) { vals.put(n.getHNodeId(), n.getValue().asString()); } oldRowValues.add(vals); oldRowIds.add(r.getId()); } HashMap<String, String> currentRow = null; String currentRowId = ""; int addedRowsCount = 0; for (int i = 0; i < oldRowValues.size(); i++) { currentRow = oldRowValues.get(i); currentRowId = oldRowIds.get(i); for (int k = 0; k < tableValues.size(); k++) { List<String> rowValues = tableValues.get(k); if (rowValues == null || rowValues.size() == 0) continue; String tableRowId = tableRowIds.get(k); if (tableRowId == null || !tableRowId.trim().equalsIgnoreCase(currentRowId.trim())) { continue; } addedRowsCount ++; Row row = null; if (addedRowsCount <= rowsCount) row = dataTable.getRows(addedRowsCount - 1, 1).get(0); else row = dataTable.addRow(factory); // System.out.println(hNodeIdList.size()); for (int j = 0; j < hNodeIdList.size(); j++) { // the first column in the table is the url column which should not be added to the table // System.out.println("j:" + j); // System.out.println(hNodeIdList.get(j)); // System.out.println(rowValues.get(j + 1)); row.setValue(hNodeIdList.get(j), rowValues.get(j), factory); } for (String id: oldHNodeIdList) { row.setValue(id, currentRow.get(id).toString(), factory); } } } } }