📄 querymessage.java
字号:
/* * The contents of this file are subject to the MonetDB Public License * Version 1.1 (the "License"); you may not use this file except in * compliance with the License. You may obtain a copy of the License at * http://monetdb.cwi.nl/Legal/MonetDBLicense-1.1.html * * Software distributed under the License is distributed on an "AS IS" * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the * License for the specific language governing rights and limitations * under the License. * * The Original Code is the MonetDB Database System. * * The Initial Developer of the Original Code is CWI. * Portions created by CWI are Copyright (C) 1997-2007 CWI. * All Rights Reserved. */package nl.cwi.monetdb.mcl.messages;import java.util.*;import nl.cwi.monetdb.mcl.*;/** * A QueryMessage is a server received message, sent by the client to * pose a new query. * * @author Fabian Groffen <Fabian.Groffen> */public class QueryMessage extends MCLVariableMessage { /** The character that identifies this message */ public static final char identifier = 'q'; private final static MCLSentence startOfMessageSentence; static { try { startOfMessageSentence = new MCLSentence(MCLSentence.STARTOFMESSAGE, "" + identifier); } catch (MCLException e) { throw new AssertionError("Unable to create core sentence"); } } /** * Constructs an empty QueryMessage. The sentences need to be added * using the addSentence() method. This constructor is suitable * when reconstructing messages from a stream. */ public QueryMessage() { // nothing has to be done here sentences = new MCLSentence[1]; variableSentences = new ArrayList(); } /** * Returns the type of this Message as an integer type. * * @return an integer value that represents the type of this Message */ public int getType() { return(identifier); } /** * Returns the start of message sentence for this Message: &e. * * @return the start of message sentence */ public MCLSentence getSomSentence() { return(startOfMessageSentence); } /** * Adds a metadata Sentence to this Message. There is virually no * limit to the number metadata Sentences, but each Sentence is * required to have a property and value. * * @param sentence the Sentence to add * @throws MCLException if the given Sentence is invalid */ public void addMetaDataSentence(MCLSentence sentence) throws MCLException { if (sentence == null) throw new MCLException("sentence may not be null"); String prop = sentence.getField(1); if (prop == null) throw new MCLException("Illegal sentence (no property): " + sentence.getString()); String value = sentence.getField(2); if (value == null) throw new MCLException("Illegal sentence (no value): " + sentence.getString()); variableSentences.add(sentence); } /** * Adds a query to this Message. There can only be one data * Sentence in a QueryMessage. This method throws an MCLException * if the data Sentence is already set. * * @param sentence the Sentence to add * @throws MCLException if the given Sentence is invalid or a data * Sentence is already set. */ public void addDataSentence(MCLSentence sentence) throws MCLException { if (sentence == null) throw new MCLException("sentence may not be null"); if (sentences[0] != null) throw new MCLException("data Sentence already set!"); sentences[0] = sentence; } /** * Adds the given Sentence to this Message if it matches the Message * type. The sentence is parsed as far as that is considered to be * necessary to validate it against the Message type. If a sentence * is not valid, an MCLException is thrown. * * @param in an MCLSentence object * @throws MCLException if the given sentence is not considered to * be valid */ public void addSentence(MCLSentence in) throws MCLException { // see if it is a supported header switch (in.getType()) { case MCLSentence.METADATA: addMetaDataSentence(in); break; case MCLSentence.QUERY: addDataSentence(in); break; default: throw new MCLException("Sentence type not allowed for this message: " + (char)in.getType()); } } // the following are message specific getters that retrieve the // values inside the message /** * Returns the query in the data Sentence. * * @return the query in its Sentence */ public MCLSentence getDataSentence() { return(sentences[0]); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -