當前位置: 首頁>>代碼示例>>Java>>正文


Java ArrayByteIterable類代碼示例

本文整理匯總了Java中jetbrains.exodus.ArrayByteIterable的典型用法代碼示例。如果您正苦於以下問題:Java ArrayByteIterable類的具體用法?Java ArrayByteIterable怎麽用?Java ArrayByteIterable使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ArrayByteIterable類屬於jetbrains.exodus包,在下文中一共展示了ArrayByteIterable類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getContributions

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
@Override
public int getContributions(ProjectFacade project, UserFacade user, String path) {
	if (user.getEmail() != null) {
		Environment env = getEnv(project.getId().toString());
		Store store = getStore(env, CONTRIBUTIONS_STORE);
		return env.computeInReadonlyTransaction(new TransactionalComputable<Integer>() {

			@Override
			public Integer compute(Transaction tx) {
				byte[] contributionKey = getContributionKey(user.getEmail(), path);
				byte[] bytes = getBytes(store.get(tx, new ArrayByteIterable(contributionKey)));
				if (bytes != null)
					return ByteBuffer.wrap(bytes).getInt();
				else
					return 0;
			}
		});
	} else {
		return 0;
	}
}
 
開發者ID:jmfgdev,項目名稱:gitplex-mit,代碼行數:22,代碼來源:DefaultCommitInfoManager.java

示例2: deleteFile

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
/**
 * Deletes existing file with the specified {@code path}.
 *
 * @param txn  {@linkplain Transaction} instance
 * @param path file path
 * @return deleted {@linkplain File} or {@code null} if no file with specified {@code path}exists.
 * @see File
 */
@Nullable
public File deleteFile(@NotNull final Transaction txn, @NotNull final String path) {
    final ArrayByteIterable key = StringBinding.stringToEntry(path);
    final ByteIterable fileMetadata;
    try (Cursor cursor = pathnames.openCursor(txn)) {
        fileMetadata = cursor.getSearchKey(key);
        if (fileMetadata != null) {
            cursor.deleteCurrent();
        }
    }
    if (fileMetadata != null) {
        final File result = new File(path, fileMetadata);
        // at first delete contents
        try (ClusterIterator iterator = new ClusterIterator(this, txn, result)) {
            while (iterator.hasCluster()) {
                iterator.deleteCurrent();
                iterator.moveToNext();
            }
        }
        return result;
    }
    return null;
}
 
開發者ID:JetBrains,項目名稱:xodus,代碼行數:32,代碼來源:VirtualFileSystem.java

示例3: getClusterConverter

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
@Override
@Nullable ClusterConverter getClusterConverter() {
    return new ClusterConverter() {
        @NotNull
        @Override
        public ByteIterable onRead(@NotNull final ByteIterable raw) {
            final int length = raw.getLength();
            int decompressedLength = length * 3 + 500;
            final byte[] result = new byte[decompressedLength];
            decompressedLength = new SnappyDecompressor().decompress(
                raw.getBytesUnsafe(), 0, length, result, 0, decompressedLength);
            return new ArrayByteIterable(result, decompressedLength);
        }

        @NotNull
        @Override
        public ByteIterable onWrite(@NotNull final ByteIterable source) {
            final int sourceLength = source.getLength();
            int compressedLength = sourceLength + sourceLength / 5 + 50;
            final byte[] compressed = new byte[compressedLength];
            compressedLength = new SnappyCompressor().compress(
                source.getBytesUnsafe(), 0, sourceLength, compressed, 0, compressedLength);
            return new ArrayByteIterable(compressed, compressedLength);
        }
    };
}
 
開發者ID:JetBrains,項目名稱:xodus,代碼行數:27,代碼來源:VfsStressTestsWithSnappyCompression.java

示例4: testBindings

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
public void testBindings() {
    final ArrayByteIterable entry0 = PropertyKey.propertyKeyToEntry(new PropertyKey(15, 71));
    final ArrayByteIterable entry1 = PropertyKey.propertyKeyToEntry(new PropertyKey(16, 24));
    final ArrayByteIterable entry2 = PropertyKey.propertyKeyToEntry(new PropertyKey(128, 24));
    final ArrayByteIterable entry3 = PropertyKey.propertyKeyToEntry(new PropertyKey(245, 71));

    Assert.assertTrue(ByteIterableUtil.compare(entry0, entry1) < 0);
    Assert.assertTrue(ByteIterableUtil.compare(entry0, entry2) < 0);
    Assert.assertTrue(ByteIterableUtil.compare(entry0, entry3) < 0);

    Assert.assertTrue(ByteIterableUtil.compare(entry1, entry2) < 0);
    Assert.assertTrue(ByteIterableUtil.compare(entry1, entry3) < 0);
    Assert.assertTrue(ByteIterableUtil.compare(entry1, entry0) > 0);

    Assert.assertTrue(ByteIterableUtil.compare(entry2, entry3) < 0);
    Assert.assertTrue(ByteIterableUtil.compare(entry2, entry1) > 0);
    Assert.assertTrue(ByteIterableUtil.compare(entry2, entry0) > 0);
}
 
開發者ID:JetBrains,項目名稱:xodus,代碼行數:19,代碼來源:TestOrdering.java

示例5: get

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
@Nullable
@Override
public ByteIterable get(@NotNull final ByteIterable key) {
    try (ITreeCursor cursor = treeNoDuplicates.openCursor()) {
        final ByteIterable value = cursor.getSearchKeyRange(getEscapedKeyWithSeparator(key));
        if (value != null && value != ByteIterable.EMPTY) {
            int keyLength = CompressedUnsignedLongByteIterable.getInt(value);
            if (key.getLength() == keyLength) {
                final ByteIterable noDupKey = new UnEscapingByteIterable(cursor.getKey());
                final byte[] noDupKeyBytes = noDupKey.getBytesUnsafe();
                if (ByteIterableUtil.compare(key.getBytesUnsafe(), keyLength, noDupKeyBytes, keyLength) == 0) {
                    return new ArrayByteIterable(Arrays.copyOfRange(noDupKeyBytes,
                            keyLength + 1, // skip separator
                            noDupKey.getLength()));
                }
            }
        }
        return null;
    }
}
 
開發者ID:JetBrains,項目名稱:xodus,代碼行數:21,代碼來源:PatriciaTreeWithDuplicates.java

示例6: getAllStoreNames

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
@NotNull
List<String> getAllStoreNames() {
    final ITree tree = this.tree;
    if (tree.getSize() == 0) {
        return Collections.emptyList();
    }
    final List<String> result = new ArrayList<>();
    final ITreeCursor cursor = tree.openCursor();
    while (cursor.getNext()) {
        final ArrayByteIterable key = new ArrayByteIterable(cursor.getKey());
        if (isStringKey(key)) {
            final String storeName = StringBinding.entryToString(key);
            if (!EnvironmentImpl.isUtilizationProfile(storeName)) {
                result.add(storeName);
            }
        }
    }
    return result;
}
 
開發者ID:JetBrains,項目名稱:xodus,代碼行數:20,代碼來源:MetaTree.java

示例7: get

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
@Override
@Nullable
public ByteIterable get(@NotNull final Transaction txn, @NotNull final ByteIterable key) {
    final ITree tree = ((TransactionBase) txn).getTree(this);
    final long treeRootAddress = tree.getRootAddress();
    final StoreGetCache storeGetCache;
    // if neither tree is empty nor mutable and StoreGetCache is on
    if (treeRootAddress != Loggable.NULL_ADDRESS && (storeGetCache = environment.getStoreGetCache()) != null) {
        ByteIterable result = storeGetCache.tryKey(treeRootAddress, key);
        if (result != null) {
            return result == NULL_CACHED_VALUE ? null : result;
        }
        result = tree.get(key);
        storeGetCache.cacheObject(treeRootAddress, key, result == null ? NULL_CACHED_VALUE : new ArrayByteIterable(result));
        return result;
    }
    return tree.get(key);
}
 
開發者ID:JetBrains,項目名稱:xodus,代碼行數:19,代碼來源:StoreImpl.java

示例8: hasNextImpl

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
private boolean hasNextImpl() {
    while (!current.hasNext()) {
        currentAddress += read;
        final int alignment = ((int) currentAddress) & (log.getCachePageSize() - 1);
        final long alignedAddress = currentAddress - alignment;
        final ArrayByteIterable page = log.cache.getPageIterable(log, alignedAddress);
        final int readBytes = page.getLength();
        if (readBytes <= alignment) { // alignment is >= 0 for sure
            read = 0;
            offset = 0;
            return false;
        }
        read = readBytes - alignment;
        current = page.iterator(alignment);
        offset = current.getOffset();
    }
    return true;
}
 
開發者ID:JetBrains,項目名稱:xodus,代碼行數:19,代碼來源:CompoundByteIterator.java

示例9: putRandomKeyValue

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
private void putRandomKeyValue(Store primary,
                               Store secondary,
                               Transaction txn,
                               int keysCount,
                               int valuesCount,
                               Persistent23TreeMap.MutableMap<Integer, Integer> testMap) {
    final int key = rnd.nextInt(keysCount);
    final ArrayByteIterable keyEntry = IntegerBinding.intToCompressedEntry(key);
    final int value = rnd.nextInt(valuesCount);
    testMap.put(key, value);
    final ArrayByteIterable valueEntry = IntegerBinding.intToCompressedEntry(value);
    final ByteIterable oldValue = primary.get(txn, keyEntry);
    primary.put(txn, keyEntry, valueEntry);
    if (oldValue != null) {
        try (Cursor cursor = secondary.openCursor(txn)) {
            Assert.assertTrue(cursor.getSearchBoth(oldValue, keyEntry));
            Assert.assertTrue(cursor.deleteCurrent());
        }
    }
    secondary.put(txn, valueEntry, keyEntry);
}
 
開發者ID:JetBrains,項目名稱:xodus,代碼行數:22,代碼來源:EnvironmentTestInMemory.java

示例10: deleteRandomKey

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
private void deleteRandomKey(Store primary,
                             Store secondary,
                             Transaction txn,
                             int keysCount,
                             Persistent23TreeMap.MutableMap<Integer, Integer> testMap) {
    final int key = rnd.nextInt(keysCount);
    testMap.remove(key);
    final ArrayByteIterable keyEntry = IntegerBinding.intToCompressedEntry(key);
    final ByteIterable oldValue = primary.get(txn, keyEntry);
    primary.delete(txn, keyEntry);
    if (oldValue != null) {
        try (Cursor cursor = secondary.openCursor(txn)) {
            Assert.assertTrue(cursor.getSearchBoth(oldValue, keyEntry));
            Assert.assertTrue(cursor.deleteCurrent());
        }
    }
}
 
開發者ID:JetBrains,項目名稱:xodus,代碼行數:18,代碼來源:EnvironmentTestInMemory.java

示例11: registerNewUser

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
private static void registerNewUser(final Environment env, final Store users, final Store emails, final String username, final String email) {
    env.executeInTransaction(new TransactionalExecutable() {
        @Override
        public void execute(@NotNull final Transaction txn) {
            final ArrayByteIterable usernameEntry = stringToEntry(username);
            final ArrayByteIterable emailEntry = stringToEntry(email);
            final boolean exists;
            try (Cursor usersCursor = users.openCursor(txn)) {
                exists = usersCursor.getSearchBoth(usernameEntry, emailEntry);
                if (!exists) {
                    users.put(txn, usernameEntry, emailEntry);
                }
            }
            if (!exists) {
                try (Cursor emailsCursor = emails.openCursor(txn)) {
                    if (emailsCursor.getSearchBoth(emailEntry, usernameEntry)) {
                        throw new ExodusException("It can't be: users & emails are inconsistent!");
                    }
                    emails.put(txn, emailEntry, usernameEntry);
                }
            }
            System.out.println((exists ? "User is already registered: " : "New user registered: ") + username + " " + email);
        }
    });
}
 
開發者ID:JetBrains,項目名稱:xodus,代碼行數:26,代碼來源:Users.java

示例12: join

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
public static ByteIterable join(ByteIterable p1, ByteIterable p2) {
  int length;
  byte[] bytes;
  byte[] p1bytes = p1.getBytesUnsafe();
  if (p1.getLength() > 65535)
    throw new IllegalArgumentException();
  length = 2 + p1.getLength() + (p2 == null ? 0 : p2.getLength());
  bytes = new byte[length];
  bytes[0] = (byte) (p1.getLength() >> 8);
  bytes[1] = (byte) (p1.getLength() & 0xFF);
  System.arraycopy(p1bytes, 0, bytes, 2, p1.getLength());
  if (p2 != null) {
    byte[] p2bytes = p2.getBytesUnsafe();
    System.arraycopy(p2bytes, 0, bytes, 2 + p1.getLength(), p2.getLength());
  }
  return new ArrayByteIterable(bytes);
}
 
開發者ID:zakgof,項目名稱:velvetdb,代碼行數:18,代碼來源:BytesUtil.java

示例13: visit

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
@Override
public void visit(User user, PullRequest request) {
	Environment env = getEnv(request.getTargetProject().getId().toString());
	Store store = getStore(env, PULL_REQUEST_STORE);
	env.executeInTransaction(new TransactionalExecutable() {
		
		@Override
		public void execute(Transaction txn) {
			store.put(txn, new StringPairByteIterable(user.getUUID(), request.getUUID()), 
					new ArrayByteIterable(longToBytes(System.currentTimeMillis()+1000L)));
		}
		
	});
}
 
開發者ID:jmfgdev,項目名稱:gitplex-mit,代碼行數:15,代碼來源:DefaultVisitManager.java

示例14: updateContribution

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
private void updateContribution(Transaction txn, Store contributionsStore, String email, String path) {
	ArrayByteIterable contributionKey = 
			new ArrayByteIterable(getContributionKey(email, path));
	byte[] contributionBytes = 
			getBytes(contributionsStore.get(txn, contributionKey));
	int contributions;
	if (contributionBytes != null)
		contributions = ByteBuffer.wrap(contributionBytes).getInt() + 1;
	else
		contributions = 1;
	ByteBuffer byteBuffer = ByteBuffer.allocate(4);
	byteBuffer.putInt(contributions);
	contributionsStore.put(txn, contributionKey, 
			new ArrayByteIterable(byteBuffer.array()));
}
 
開發者ID:jmfgdev,項目名稱:gitplex-mit,代碼行數:16,代碼來源:DefaultCommitInfoManager.java

示例15: getChildren

import jetbrains.exodus.ArrayByteIterable; //導入依賴的package包/類
@Override
public Set<ObjectId> getChildren(Project project, final ObjectId parent) {
	Environment env = getEnv(project.getId().toString());
	final Store store = getStore(env, COMMITS_STORE);

	return env.computeInReadonlyTransaction(new TransactionalComputable<Set<ObjectId>>() {

		@Override
		public Set<ObjectId> compute(Transaction txn) {
			Set<ObjectId> children = new HashSet<>();
			
			byte[] keyBytes = new byte[20];
			parent.copyRawTo(keyBytes, 0);
			byte[] valueBytes = getBytes(store.get(txn, new ArrayByteIterable(keyBytes)));
			if (valueBytes != null) {
				if (valueBytes.length % 20 == 0) {
					for (int i=0; i<valueBytes.length/20; i++) {
						children.add(ObjectId.fromRaw(valueBytes, i*20));
					}
				} else { 
					/*
					 * skip the leading byte, which tells whether or not the commit 
					 * has been processed
					 */
					for (int i=0; i<(valueBytes.length-1)/20; i++) {
						children.add(ObjectId.fromRaw(valueBytes, i*20+1));
					}
				}
			}
			return children;
		}
		
	});
}
 
開發者ID:jmfgdev,項目名稱:gitplex-mit,代碼行數:35,代碼來源:DefaultCommitInfoManager.java


注:本文中的jetbrains.exodus.ArrayByteIterable類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。