/*- * See the file LICENSE for redistribution information. * * Copyright (c) 2002-2009 Oracle. All rights reserved. * * $Id$ */ package collections.ship.marshal; import java.io.FileNotFoundException; import java.util.Iterator; import java.util.Set; import com.sleepycat.collections.TransactionRunner; import com.sleepycat.collections.TransactionWorker; import com.sleepycat.db.DatabaseException; /** * Sample is the main entry point for the sample program and may be run as * follows: * *
* java collections.ship.marshal.Sample * [-h* *] *
The default for the home directory is ./tmp -- the tmp subdirectory of * the current directory where the sample is run. To specify a different home * directory, use the -home option. The home directory must exist before * running the sample. To recreate the sample database from scratch, delete * all files in the home directory before running the sample.
* * @author Mark Hayes */ public class Sample { private SampleDatabase db; private SampleViews views; /** * Run the sample program. */ public static void main(String[] args) { System.out.println("\nRunning sample: " + Sample.class); // Parse the command line arguments. // String homeDir = "./tmp"; for (int i = 0; i < args.length; i += 1) { if (args[i].equals("-h") && i < args.length - 1) { i += 1; homeDir = args[i]; } else { System.err.println("Usage:\n java " + Sample.class.getName() + "\n [-hNote the use of special iterator() methods. These are used here * with indices to find the shipments for certain keys.
*/ private class PrintDatabase implements TransactionWorker { public void doWork() throws Exception { printValues("Parts", views.getPartSet().iterator()); printValues("Suppliers", views.getSupplierSet().iterator()); printValues("Suppliers for City Paris", views.getSupplierByCityMap().duplicates( "Paris").iterator()); printValues("Shipments", views.getShipmentSet().iterator()); printValues("Shipments for Part P1", views.getShipmentByPartMap().duplicates( new PartKey("P1")).iterator()); printValues("Shipments for Supplier S1", views.getShipmentBySupplierMap().duplicates( new SupplierKey("S1")).iterator()); } } /** * Populate the part entities in the database. If the part set is not * empty, assume that this has already been done. */ private void addParts() { Set parts = views.getPartSet(); if (parts.isEmpty()) { System.out.println("Adding Parts"); parts.add(new Part("P1", "Nut", "Red", new Weight(12.0, Weight.GRAMS), "London")); parts.add(new Part("P2", "Bolt", "Green", new Weight(17.0, Weight.GRAMS), "Paris")); parts.add(new Part("P3", "Screw", "Blue", new Weight(17.0, Weight.GRAMS), "Rome")); parts.add(new Part("P4", "Screw", "Red", new Weight(14.0, Weight.GRAMS), "London")); parts.add(new Part("P5", "Cam", "Blue", new Weight(12.0, Weight.GRAMS), "Paris")); parts.add(new Part("P6", "Cog", "Red", new Weight(19.0, Weight.GRAMS), "London")); } } /** * Populate the supplier entities in the database. If the supplier set is * not empty, assume that this has already been done. */ private void addSuppliers() { Set suppliers = views.getSupplierSet(); if (suppliers.isEmpty()) { System.out.println("Adding Suppliers"); suppliers.add(new Supplier("S1", "Smith", 20, "London")); suppliers.add(new Supplier("S2", "Jones", 10, "Paris")); suppliers.add(new Supplier("S3", "Blake", 30, "Paris")); suppliers.add(new Supplier("S4", "Clark", 20, "London")); suppliers.add(new Supplier("S5", "Adams", 30, "Athens")); } } /** * Populate the shipment entities in the database. If the shipment set * is not empty, assume that this has already been done. */ private void addShipments() { Set shipments = views.getShipmentSet(); if (shipments.isEmpty()) { System.out.println("Adding Shipments"); shipments.add(new Shipment("P1", "S1", 300)); shipments.add(new Shipment("P2", "S1", 200)); shipments.add(new Shipment("P3", "S1", 400)); shipments.add(new Shipment("P4", "S1", 200)); shipments.add(new Shipment("P5", "S1", 100)); shipments.add(new Shipment("P6", "S1", 100)); shipments.add(new Shipment("P1", "S2", 300)); shipments.add(new Shipment("P2", "S2", 400)); shipments.add(new Shipment("P2", "S3", 200)); shipments.add(new Shipment("P2", "S4", 200)); shipments.add(new Shipment("P4", "S4", 300)); shipments.add(new Shipment("P5", "S4", 400)); } } /** * Print the objects returned by an iterator of entity value objects. */ private void printValues(String label, Iterator iterator) { System.out.println("\n--- " + label + " ---"); while (iterator.hasNext()) { System.out.println(iterator.next().toString()); } } }