/* * This file is part of rasdaman community. * * Rasdaman community is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Rasdaman community is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with rasdaman community. If not, see . * * Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009 Peter Baumann / rasdaman GmbH. * * For more information please see * or contact Peter Baumann via . */ #include #include #include #include "adminif.hh" #include "databaseif.hh" #include "oidif.hh" #include "transactionif.hh" #include "alltypes.hh" #include "typefactory.hh" #include "dbmddcoll.hh" #include "dbmddcolloidentry.hh" #include "dbmddobj.hh" #include "raslib/rmdebug.hh" RMINITGLOBALS('C') int RManDebug2 = 8; int RManModule = 4; int main(int argc, char* argv[]) { if (argc >= 2) { AdminIf* myAdmin; DatabaseIf database; TransactionIf ta; RManDebug = 6; myAdmin = AdminIf::instance(); database.open("RMAN"); ta.begin(&database); DBIterId* iter = 0; DBMDDColl* coll = 0; DBMDDCollOIdEntry* entry = 0; DBMDDObj* obj = 0; MDDIterator* mdditerobj = 0; OId* id1 = 0; OId* id2 = 0; OId* id3 = 0; int i = 0; MDDBaseType* type = 0; DBMinterval* dom = 0; switch (atoi(argv[1])) { case 1: cout << "Create Object with mdddtype " << atol(argv[2]) << " domainid " << atol(argv[3]) << " objIx " << atol(argv[4]) << endl; id1 = new OId(atol(argv[2]), OId::MDDTYPEOID); id2 = new OId(atol(argv[3]), OId::DBMINTERVALOID); id3 = new OId(); cout << *id1 << " " << *id2 << endl; type = (const MDDBaseType*)TypeFactory::mapMDDType(*id1); cout << "MDDType\t: " << type->getName() << endl; dom = TypeFactory::mapDBMinterval(*id2); cout << "Domain\t: " << *dom << endl; OId::allocateOId(*id3, OId::MDDOID); cout << "MDDOId " << *id3 << endl; obj = DBMDDObj::getNonInitializedMDD((char*)0, *id3); cout << "Got Noninitialized at" << obj << endl; obj->initialize((const MDDBaseType*)type, *dom, atol(argv[4])); break; case 2: cout << "Creating Object Iterator" << endl; mdditerobj = &MDDInit::createMDDObjectIterator(); for (i = 0; mdditerobj->not_done(); mdditerobj->advance(), i++) { cout << "Iter returned for " << i << ". " << mdditerobj->get_element()->getOId() << " with domain " << mdditerobj->get_element()->getDefinitionDomain() << endl; } break; case 3: id1 = new OId(atol(argv[2]), OId::MDDOID); cout << "Delete Object with id: " << *id1 << endl; MDDInit::deleteMDDObject(*id1); cout << "Deleted" << endl; mdditerobj = &MDDInit::createMDDObjectIterator(); for (i = 0; mdditerobj->not_done(); mdditerobj->advance(), i++) { cout << "Iter returned for " << i << ". " << mdditerobj->get_element()->getOId() << " with domain " << mdditerobj->get_element()->getDefinitionDomain() << endl; } cout << "DONE " << endl; break; case 4: id1 = new OId(atol(argv[2]), OId::MDDOID); id2 = new OId(atol(argv[3]), OId::MDDCOLLOID); cout << "Insert Object with id: " << *id1 << " into collection with id: " << *id2 << endl; coll = MDDInit::mapMDDCollection(*id2); coll->insert(MDDInit::mapMDDObject(*id1)); for (iter = &coll->createIterator(); iter->not_done(); iter->advance(), i++) cout << "Iter returned for " << i << ". " << iter->get_element()->getOId() << endl; break; case 5: id1 = new OId(atol(argv[2]), OId::MDDOID); id2 = new OId(atol(argv[3]), OId::MDDCOLLOID); cout << "Remove Object with id " << *id1 << " from collection with id: " << *id2 << endl; coll = MDDInit::mapMDDCollection(*id2); coll->remove(MDDInit::mapMDDObject(*id1)); for (iter = &coll->createIterator(); iter->not_done(); iter->advance(), i++) cout << "Iter returned for " << i << ". " << iter->get_element()->getOId() << endl; } if (argv[5]) { if ((strcmp(argv[5],"commit") == 0)) { cout << "commiting" << endl; ta.commit(); } } cout << "aborting" << endl; ta.abort(); database.close(); } else { cout << "USAGE:" << endl; cout << "\t1: create object" << endl << "\t\tmddtypeid domainid objix" << endl; cout << "\t2: object iterator" << endl << "\t\t" << endl; cout << "\t3: delete object" << endl << "\t\tobjectid" << endl; cout << "\t4: insert object in collection" << endl << "\t\tobjectid collectionid" << endl; cout << "\t5: remove object from collection" << endl << "\t\tobjectid collectionid" << endl; cout << "5th argument must be abort/commit" << endl; } }