/******************************************************************************* * Copyright (c) 2007, 2018 Association for Decentralized Information Management * in Industry THTH ry. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * VTT Technical Research Centre of Finland - initial API and implementation *******************************************************************************/ package org.simantics.db.impl.query; import org.simantics.db.exception.DatabaseException; import org.simantics.db.impl.graph.ReadGraphImpl; import org.simantics.db.request.RequestFlags; import gnu.trove.list.array.TByteArrayList; public abstract class UnaryQuery extends CacheEntryBase implements Query { final public int id; public UnaryQuery(int r) { assert(r != 0); this.id = r; } @Override int makeHash() { return id; } @Override public int type() { return RequestFlags.INVALIDATE; } @Override final public boolean equals(Object object) { if (this == object) return true; else if (object == null) return false; else if (getClass() != object.getClass()) return false; UnaryQuery other = (UnaryQuery)object; return id == other.id; } @Override final public Query getQuery() { assert(!isDiscarded()); return this; } abstract public void removeEntry(QueryProcessor provider); public Object get(ReadGraphImpl graph, Procedure procedure) throws Throwable { if(procedure != null) { performFromCache(graph, procedure); } else { checkAndThrow(); } return getResult(); } @Override boolean isImmutable(ReadGraphImpl graph) throws DatabaseException { return graph.processor.isImmutable(id); } @Override public long cluster(QueryProcessor processor) { return processor.cluster(id); } @Override public void serializeKey(QuerySerializer serializer) { serializer.addResource(id); } }