Skip to content

Commit

Permalink
Do not register tokens explicitly in 4.4
Browse files Browse the repository at this point in the history
  • Loading branch information
soerenreichardt committed Jan 16, 2024
1 parent c550cf8 commit 3cf25d4
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ public final class InMemoryStorageEngineImpl implements StorageEngine {
) {
this.databaseLayout = databaseLayout;
this.graphStore = getGraphStoreFromCatalog(databaseLayout.getDatabaseName());
this.txStateVisitor = new InMemoryTransactionStateVisitor(graphStore, tokenHolders);
this.txStateVisitor = new InMemoryTransactionStateVisitor(graphStore, tokenHolders, false);
this.commandCreationContext = new InMemoryCommandCreationContextImpl();
this.tokenManager = new TokenManager(
tokenHolders,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,14 +48,24 @@ public class InMemoryTransactionStateVisitor extends TxStateVisitor.Adapter {

private final CypherGraphStore graphStore;
private final TokenHolders tokenHolders;
private final boolean doRegisterNewTokens;
private final IntObjectMap<UpdatableNodeProperty> nodePropertiesCache;

public InMemoryTransactionStateVisitor(
CypherGraphStore graphStore,
TokenHolders tokenHolders
) {
this(graphStore, tokenHolders, true);
}

public InMemoryTransactionStateVisitor(
CypherGraphStore graphStore,
TokenHolders tokenHolders,
boolean doRegisterNewTokens
) {
this.graphStore = graphStore;
this.tokenHolders = tokenHolders;
this.doRegisterNewTokens = doRegisterNewTokens;
this.nodePropertiesCache = new IntObjectHashMap<>();
}

Expand Down Expand Up @@ -112,18 +122,24 @@ public void visitNodeLabelChanges(

@Override
public void visitCreatedLabelToken(long id, String name, boolean internal) {
tokenHolders.labelTokens().addToken(new NamedToken(name, (int) id, internal));
graphStore.addNodeLabel(NodeLabel.of(name));
if (doRegisterNewTokens) {
tokenHolders.labelTokens().addToken(new NamedToken(name, (int) id, internal));
graphStore.addNodeLabel(NodeLabel.of(name));
}
}

@Override
public void visitCreatedPropertyKeyToken(long id, String name, boolean internal) {
tokenHolders.propertyKeyTokens().addToken(new NamedToken(name, (int) id, internal));
if (doRegisterNewTokens) {
tokenHolders.propertyKeyTokens().addToken(new NamedToken(name, (int) id, internal));
}
}

@Override
public void visitCreatedRelationshipTypeToken(long id, String name, boolean internal) {
tokenHolders.relationshipTypeTokens().addToken(new NamedToken(name, (int) id, internal));
if (doRegisterNewTokens) {
tokenHolders.relationshipTypeTokens().addToken(new NamedToken(name, (int) id, internal));
}
}

private void visitAddedOrChangedNodeProperties(long nodeId, Iterator<StorageProperty> added, Iterator<StorageProperty> changed) {
Expand Down

0 comments on commit 3cf25d4

Please sign in to comment.