All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.evento.parser.model.handler.InvocationHandler Maven / Gradle / Ivy

There is a newer version: ev1.10.3
Show newest version
package org.evento.parser.model.handler;

import org.evento.parser.model.payload.Command;
import org.evento.parser.model.payload.Invocation;
import org.evento.parser.model.payload.Query;

import java.util.HashMap;
import java.util.Map;

/**
 * The InvocationHandler class represents a handler for invocations.
 * It extends the Handler class and implements the HasCommandInvocations and HasQueryInvocations interfaces.
 */
public class InvocationHandler extends Handler implements HasCommandInvocations, HasQueryInvocations {
	private HashMap invokedCommands = new HashMap<>();
	private HashMap invokedQueries = new HashMap<>();


	/**
	 * The InvocationHandler class represents a handler for invocations.
	 * It extends the Handler class and implements the HasCommandInvocations and HasQueryInvocations interfaces.
     * @param payload the invocation payload
     * @param line line on the file
     */
	public InvocationHandler(Invocation payload, int line) {
		super(payload, line);
	}

	/**
	 * The InvocationHandler class represents a handler for invocations.
	 * It extends the Handler class and implements the HasCommandInvocations and HasQueryInvocations interfaces.
	 */
	public InvocationHandler() {
	}

	/**
	 * Adds a command invocation to the list of invoked commands.
	 *
	 * @param command The command object to be added.
	 * @param line    The line number where the command invocation occurs.
	 */
	@Override
	public void addCommandInvocation(Command command, int line) {
		invokedCommands.put(line, command);
	}

	/**
	 * This method returns a map of command invocations.
	 *
	 * @return A map of command invocations where the key is the line number and the value is the Command object.
	 */
	@Override
	public Map getCommandInvocations() {
		return invokedCommands;
	}

	/**
	 * Adds a query invocation to the list of invoked queries.
	 *
	 * @param query The query object to be added.
	 * @param line  The line number where the query invocation occurs.
	 */
	@Override
	public void addQueryInvocation(Query query, int line) {
		invokedQueries.put(line, query);

	}

	/**
	 * Returns a map of query invocations.
	 *
	 * @return A map where the key is the line number of the query invocation and the value is the Query object.
	 */
	@Override
	public Map getQueryInvocations() {
		return invokedQueries;
	}

	/**
	 * Returns a map of command invocations.
	 *
	 * @return A map of command invocations, where the key is the line number and the value is the Command object.
	 */
	public HashMap getInvokedCommands() {
		return invokedCommands;
	}

	/**
	 * Sets the map of invoked commands.
	 *
	 * @param invokedCommands The map of invoked commands to be set.
	 */
	public void setInvokedCommands(HashMap invokedCommands) {
		this.invokedCommands = invokedCommands;
	}

	/**
	 * Retrieves a map of invoked queries.
	 *
	 * @return A map where the key is the line number of the query invocation and the value is the Query object representing the invocation.
	 */
	public HashMap getInvokedQueries() {
		return invokedQueries;
	}

	/**
	 * Sets the map of invoked queries.
	 *
	 * @param invokedQueries The map of invoked queries to be set.
	 */
	public void setInvokedQueries(HashMap invokedQueries) {
		this.invokedQueries = invokedQueries;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy