/* * DBeaver - Universal Database Manager * Copyright (C) 2010-2017 Serge Rider (serge@jkiss.org) * * 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.jkiss.dbeaver.runtime.sql.commands; import org.jkiss.dbeaver.DBException; import org.jkiss.dbeaver.model.exec.DBCException; import org.jkiss.dbeaver.model.sql.SQLControlCommand; import org.jkiss.dbeaver.model.sql.SQLScriptContext; import org.jkiss.dbeaver.model.sql.eval.ScriptEvaluateEngine; import org.jkiss.dbeaver.runtime.sql.SQLControlCommandHandler; /** * Control command handler */ public class SQLCommandSet implements SQLControlCommandHandler { @Override public boolean handleCommand(SQLControlCommand command, SQLScriptContext scriptContext) throws DBException { String parameter = command.getParameter(); int divPos = parameter.indexOf('='); if (divPos == -1) { throw new DBCException("Bad set syntax. Expected syntax:\n@set varName = value or expression"); } String varName = parameter.substring(0, divPos).trim(); String varValue = parameter.substring(divPos + 1).trim(); Object varEvaluated = ScriptEvaluateEngine.getEngine(scriptContext).evaluateExpression(varValue); scriptContext.getVariables().put(varName, varEvaluated); return true; } ; }