/* * Copyright 2009 DuraSpace. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.mulgara.query.operation; import org.mulgara.connection.Connection; import org.mulgara.query.QueryException; /** * This interface is for use by TqlAutoInterpreter for managing operations that * operate on transactions in some way. * * @created Nov 8, 2007 * @author Paula Gearon * @copyright © 2007 <a href="mailto:pgearon@users.sourceforge.net">Paula Gearon</a> * @licence <a href="{@docRoot}/../../LICENCE.txt">Open Software License v3.0</a> */ public interface TxOp { /** * Perform the operation for manipulating this transaction. * @param conn The connection to perform the operation on. * @return The resulting message. * @throws QueryException The operation failed. */ Object execute(Connection conn) throws QueryException; /** * Indicates if this operation should result in the transaction finishing or continuing. * @return <code>true</code> if the transaction stays open, <code>false</code> if it closes. */ boolean stayInTx(); /** * Sets the result message. This is for internal use only. * @param msg A text message associated with the result of this operation. */ String setResultMessage(String msg); /** * Gets the result message. This will be mixed in from the Command interface. * @return A text message associated with the result of this operation. */ String getResultMessage(); }