org.mwg.plugin.Resolver Maven / Gradle / Ivy
package org.mwg.plugin;
import org.mwg.Callback;
import org.mwg.Graph;
import org.mwg.Node;
/**
* Resolver plugin, able to change the semantic of Many World Graph
*/
public interface Resolver {
/**
* Initializes the resolver with the graph passed as parameter
*
* @param graph graph this resolver belongs to
*/
void init(Graph graph);
/**
* Initializes backend structures for the newly created node passed as parameter
*
* @param node The node to initialize.
* @param typeCode The coded type param to initialize
*/
void initNode(Node node, long typeCode);
/**
* Put additional marks to the current node chunks and return the current type of the node
*
* @param node origin node to additionally mark
* @return node type code
*/
long markNodeAndGetType(org.mwg.Node node);
/**
* Initializes a newly created world, and sets the parent relationship.
*
* @param parentWorld The parent world
* @param childWorld The new world to initialize.
*/
void initWorld(long parentWorld, long childWorld);
/**
* Frees a node structure so it might be recycled.
*
* @param node The node to free.
*/
void freeNode(Node node);
/**
* Creates a lookup job to retrieve a particular node based on world/time/node_id
*
* @param world The world identifier
* @param time The timepoint.
* @param id The id of the node to retrieve.
* @param callback Called when the node is retrieved.
* @return The created lookup job to be given to the scheduler.
*/
Job lookupJob(long world, long time, long id, Callback callback);
/**
* Creates and schedules a lookup task.
*
* @param world The world identifier
* @param time The timepoint.
* @param id The id of the node to retrieve.
* @param callback Called when the node is retrieved.
*/
void lookup(long world, long time, long id, Callback callback);
/**
* Resolves the state of a node, to access attributes, relations, and indexes.
* In case dephasing is allowed the latest state available is returned.
* In case dephasing is not allowed (false), the state is phased, i.e.: cloned at the timePoint of the node.
*
* @param node The node for which the state must be collected.
* @param allowDephasing Specifies if the requested state can be dephased. If not, it will be cloned at the timepoint of the node.
* @return The resolved state of the node.
*/
NodeState resolveState(Node node, boolean allowDephasing);
/**
* @param node The node for which the state must be collected.
* @param world The world for which the new state must be created.
* @param time The time for which the new state must be created.
* @return The newly empoty created state of the node.
*/
NodeState newState(Node node, long world, long time);
/**
* Resolves the timePoints of a node.
*
* @param node The node for which timepoints are requested.
* @param beginningOfSearch The earliest timePoint of the search (included).
* @param endOfSearch The latest timePoint of the search (included).
* @param callback Called when finished, with the list of timepoints included in the bounds for this node.
*/
void resolveTimepoints(Node node, long beginningOfSearch, long endOfSearch, Callback callback);
/**
* Maps a String to a unique long. Can be reversed using {@link #hashToString(long)}.
*
* @param name The string value to be mapped.
* @param insertIfNotExists indicate if the string has to be inserted if not existing in the global dictionary
* @return The unique long identifier for the string.
*/
long stringToHash(String name, boolean insertIfNotExists);
/**
* Returns the String associated to a hash.
*
* @param key The long key.
* @return The string value associated to the long key.
*/
String hashToString(long key);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy