Search in sources :

Example 6 with Record

use of org.bimserver.database.Record in project BIMserver by opensourceBIM.

the class FollowReferenceStackFrame method process.

@Override
public boolean process() throws BimserverDatabaseException, QueryException {
    if (getQueryObjectProvider().hasRead(oid)) {
        processPossibleIncludes(currentObject, null, include);
        return true;
    }
    if (hasRun) {
        return true;
    }
    hasRun = true;
    if (oid == -1) {
        throw new BimserverDatabaseException("Cannot get object for oid " + oid);
    }
    EClass eClass = getQueryObjectProvider().getDatabaseSession().getEClassForOid(oid);
    ByteBuffer mustStartWith = ByteBuffer.wrap(new byte[12]);
    mustStartWith.putInt(getReusable().getPid());
    mustStartWith.putLong(oid);
    ByteBuffer startSearchWith = ByteBuffer.wrap(new byte[16]);
    startSearchWith.putInt(getReusable().getPid());
    startSearchWith.putLong(oid);
    startSearchWith.putInt(-getReusable().getRid());
    SearchingRecordIterator recordIterator = getQueryObjectProvider().getDatabaseSession().getKeyValueStore().getRecordIterator(eClass.getEPackage().getName() + "_" + eClass.getName(), mustStartWith.array(), startSearchWith.array(), getQueryObjectProvider().getDatabaseSession());
    try {
        Record record = recordIterator.next();
        if (record == null) {
            return true;
        }
        getQueryObjectProvider().incReads();
        ByteBuffer keyBuffer = ByteBuffer.wrap(record.getKey());
        ByteBuffer valueBuffer = ByteBuffer.wrap(record.getValue());
        // pid
        keyBuffer.getInt();
        long keyOid = keyBuffer.getLong();
        int keyRid = -keyBuffer.getInt();
        if (keyRid <= getReusable().getRid()) {
            if (valueBuffer.capacity() == 1 && valueBuffer.get(0) == -1) {
                valueBuffer.position(valueBuffer.position() + 1);
                return true;
            // deleted entity
            } else {
                currentObject = convertByteArrayToObject(eClass, keyOid, valueBuffer, keyRid);
                if (currentObject != null) {
                    EReference opposite = getPackageMetaData().getInverseOrOpposite(currentObject.eClass(), fromReference);
                    if (opposite != null) {
                        Object x = currentObject.get(opposite.getName());
                        if (x instanceof List) {
                            List<Long> list = (List<Long>) x;
                            int index = list.indexOf(fromOid);
                            currentObject.addUseForSerialization(opposite, index);
                        } else {
                            currentObject.addUseForSerialization(opposite);
                        }
                    }
                }
                processPossibleIncludes(currentObject, null, include);
            }
        } else {
            return true;
        }
    } finally {
        recordIterator.close();
    }
    return true;
}
Also used : BimserverDatabaseException(org.bimserver.BimserverDatabaseException) EClass(org.eclipse.emf.ecore.EClass) Record(org.bimserver.database.Record) List(java.util.List) SearchingRecordIterator(org.bimserver.database.SearchingRecordIterator) ByteBuffer(java.nio.ByteBuffer) EReference(org.eclipse.emf.ecore.EReference)

Example 7 with Record

use of org.bimserver.database.Record in project BIMserver by opensourceBIM.

the class BimServer method checkPidRid.

private int checkPidRid(DatabaseSession session, Project project, int pid, int rid) throws BimserverDatabaseException, BimserverLockConflictException {
    ByteBuffer buffer = ByteBuffer.allocate(4);
    buffer.putInt(pid);
    int removed = 0;
    KeyValueStore keyValueStore = session.getKeyValueStore();
    PackageMetaData packageMetaData = bimDatabase.getMetaDataManager().getPackageMetaData(project.getSchema());
    for (EClass eClass : packageMetaData.getAllClasses()) {
        String tableName = bimDatabase.getTableName(eClass);
        if (!keyValueStore.isTransactional(session, tableName)) {
            try (RecordIterator iterator = keyValueStore.getRecordIterator(tableName, buffer.array(), buffer.array(), session, true)) {
                Record record = iterator.next();
                while (record != null) {
                    ByteBuffer keyBuffer = ByteBuffer.wrap(record.getKey());
                    if (keyBuffer.capacity() != 16) {
                        throw new BimserverDatabaseException("Unexpected key size: " + keyBuffer.capacity());
                    }
                    // pid
                    keyBuffer.getInt();
                    // oid
                    keyBuffer.getLong();
                    // rid
                    int recordRid = -keyBuffer.getInt();
                    if (recordRid > rid) {
                        keyValueStore.delete(tableName, record.getKey(), session);
                        removed++;
                    }
                    record = iterator.next();
                }
            }
        }
    }
    return removed;
}
Also used : RecordIterator(org.bimserver.database.RecordIterator) EClass(org.eclipse.emf.ecore.EClass) PackageMetaData(org.bimserver.emf.PackageMetaData) KeyValueStore(org.bimserver.database.KeyValueStore) BerkeleyKeyValueStore(org.bimserver.database.berkeley.BerkeleyKeyValueStore) Record(org.bimserver.database.Record) ByteBuffer(java.nio.ByteBuffer)

Aggregations

ByteBuffer (java.nio.ByteBuffer)7 Record (org.bimserver.database.Record)7 EClass (org.eclipse.emf.ecore.EClass)7 BimserverDatabaseException (org.bimserver.BimserverDatabaseException)5 RecordIterator (org.bimserver.database.RecordIterator)5 BimserverLockConflictException (org.bimserver.database.BimserverLockConflictException)4 KeyValueStore (org.bimserver.database.KeyValueStore)4 SearchingRecordIterator (org.bimserver.database.SearchingRecordIterator)2 PackageMetaData (org.bimserver.emf.PackageMetaData)2 List (java.util.List)1 AtomicLong (java.util.concurrent.atomic.AtomicLong)1 BerkeleyKeyValueStore (org.bimserver.database.berkeley.BerkeleyKeyValueStore)1 HashMapVirtualObject (org.bimserver.shared.HashMapVirtualObject)1 EReference (org.eclipse.emf.ecore.EReference)1 EStructuralFeature (org.eclipse.emf.ecore.EStructuralFeature)1