Clover coverage report -
Coverage timestamp: Sun Nov 1 2009 23:08:24 UTC
file stats: LOC: 87   Methods: 2
NCLOC: 49   Classes: 1
 
 Source file Conditionals Statements Methods TOTAL
DeleteDocument.java 0% 0% 0% 0%
coverage
 1    /*
 2    * Licensed to the Apache Software Foundation (ASF) under one or more
 3    * contributor license agreements. See the NOTICE file distributed with
 4    * this work for additional information regarding copyright ownership.
 5    * The ASF licenses this file to You under the Apache License, Version 2.0
 6    * (the "License"); you may not use this file except in compliance with
 7    * the License. You may obtain a copy of the License at
 8    *
 9    * http://www.apache.org/licenses/LICENSE-2.0
 10    *
 11    * Unless required by applicable law or agreed to in writing, software
 12    * distributed under the License is distributed on an "AS IS" BASIS,
 13    * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 14    * See the License for the specific language governing permissions and
 15    * limitations under the License.
 16    *
 17    * $Id: DeleteDocument.java 578602 2007-09-23 20:33:31Z natalia $
 18    */
 19   
 20    package org.apache.xindice.tools.command;
 21   
 22    import org.apache.xindice.tools.XMLTools;
 23   
 24    import org.xmldb.api.DatabaseManager;
 25    import org.xmldb.api.base.Collection;
 26    import org.xmldb.api.base.Resource;
 27   
 28    /**
 29    * DeleteDocument.java is designed to let the user delete or drop
 30    * a Document, referred by the Key, from a specific Collection or Nested
 31    * Collection.
 32    *
 33    * @version $Revision: 578602 $, $Date: 2007-09-23 13:33:31 -0700 (Sun, 23 Sep 2007) $
 34    */
 35    public class DeleteDocument extends Command {
 36   
 37  0 public boolean execute(XMLTools.Config table) throws Exception {
 38  0 if (table.getString(XMLTools.COLLECTION) == null) {
 39  0 System.out.println("ERROR : Collection and switch required");
 40  0 return false;
 41    }
 42   
 43  0 if (table.getString(XMLTools.NAME_OF) == null) {
 44  0 System.out.println("ERROR : Document Key and switch required");
 45  0 return false;
 46    }
 47   
 48  0 Collection col = null;
 49  0 try {
 50    // Get a Collection reference to the collection to be deleted
 51  0 String colstring = normalizeCollectionURI(table.getString(XMLTools.COLLECTION),
 52    table.getBoolean(XMLTools.LOCAL));
 53   
 54  0 col = DatabaseManager.getCollection(colstring);
 55  0 if (col == null) {
 56  0 System.out.println("ERROR : Collection not found!");
 57  0 return false;
 58    }
 59   
 60  0 Resource colresource = col.getResource(table.getString(XMLTools.NAME_OF));
 61   
 62  0 col.removeResource(colresource);
 63  0 System.out.println("DELETED: " + table.getString(XMLTools.COLLECTION) + "/" + table.getString(XMLTools.NAME_OF));
 64    } finally {
 65  0 if (col != null) {
 66  0 col.close();
 67    }
 68    }
 69   
 70  0 return true;
 71    }
 72   
 73  0 public void usage() {
 74  0 System.out.println("Format: xindice dd -c <context> [-l [-d <path>]] [-v] [parameters...]");
 75  0 System.out.println();
 76  0 System.out.println("Deletes a document/binary resource, referred by the key, from a specific");
 77  0 System.out.println("collection");
 78  0 System.out.println();
 79  0 System.out.println("Command-specific switches:");
 80  0 System.out.println(" -n|--nameOf <name>");
 81  0 System.out.println(" Key of the resource to be deleted");
 82  0 System.out.println();
 83  0 System.out.println("Examples:");
 84  0 System.out.println(" xindice dd -c /db/test -n myxmldocument");
 85  0 System.out.println();
 86    }
 87    }