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

antlr3.com.google.gerrit.index.query.QueryParser Maven / Gradle / Ivy

// $ANTLR 3.5.2 antlr3/com/google/gerrit/index/query/Query.g 2021-01-26 17:34:29

package com.google.gerrit.index.query;


import org.antlr.runtime.*;
import java.util.Stack;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.util.HashMap;

import org.antlr.runtime.tree.*;


@SuppressWarnings("all")
public class QueryParser extends Parser {
	public static final String[] tokenNames = new String[] {
		"", "", "", "", "AND", "DEFAULT_FIELD", "EXACT_PHRASE", 
		"FIELD_NAME", "NON_WORD", "NOT", "OR", "SINGLE_WORD", "WS", "'('", "')'", 
		"'-'", "':'"
	};
	public static final int EOF=-1;
	public static final int T__13=13;
	public static final int T__14=14;
	public static final int T__15=15;
	public static final int T__16=16;
	public static final int AND=4;
	public static final int DEFAULT_FIELD=5;
	public static final int EXACT_PHRASE=6;
	public static final int FIELD_NAME=7;
	public static final int NON_WORD=8;
	public static final int NOT=9;
	public static final int OR=10;
	public static final int SINGLE_WORD=11;
	public static final int WS=12;

	// delegates
	public Parser[] getDelegates() {
		return new Parser[] {};
	}

	// delegators


	public QueryParser(TokenStream input) {
		this(input, new RecognizerSharedState());
	}
	public QueryParser(TokenStream input, RecognizerSharedState state) {
		super(input, state);
	}

	protected TreeAdaptor adaptor = new CommonTreeAdaptor();

	public void setTreeAdaptor(TreeAdaptor adaptor) {
		this.adaptor = adaptor;
	}
	public TreeAdaptor getTreeAdaptor() {
		return adaptor;
	}
	@Override public String[] getTokenNames() { return QueryParser.tokenNames; }
	@Override public String getGrammarFileName() { return "antlr3/com/google/gerrit/index/query/Query.g"; }


	  static class QueryParseInternalException extends RuntimeException {
	    private static final long serialVersionUID = 1L;

	    QueryParseInternalException(final String msg) {
	      super(msg);
	    }
	  }

	  public static Tree parse(final String str)
	    throws QueryParseException {
	    try {
	      final QueryParser p = new QueryParser(
	        new TokenRewriteStream(
	          new QueryLexer(
	            new ANTLRStringStream(str)
	          )
	        )
	      );
	      return (Tree)p.query().getTree();
	    } catch (QueryParseInternalException e) {
	      throw new QueryParseException(e.getMessage());
	    } catch (RecognitionException e) {
	      throw new QueryParseException(e.getMessage());
	    }
	  }

	  public static boolean isSingleWord(final String value) {
	    try {
	      final QueryLexer lexer = new QueryLexer(new ANTLRStringStream(value));
	      lexer.mSINGLE_WORD();
	      return lexer.nextToken().getType() == QueryParser.EOF;
	    } catch (QueryParseInternalException e) {
	      return false;
	    } catch (RecognitionException e) {
	      return false;
	    }
	  }

	  @Override
	  public void displayRecognitionError(String[] tokenNames,
	                                      RecognitionException e) {
	      String hdr = getErrorHeader(e);
	      String msg = getErrorMessage(e, tokenNames);
	      throw new QueryParseInternalException(hdr + " " + msg);
	  }


	public static class query_return extends ParserRuleReturnScope {
		Object tree;
		@Override
		public Object getTree() { return tree; }
	};


	// $ANTLR start "query"
	// antlr3/com/google/gerrit/index/query/Query.g:92:1: query : conditionOr ;
	public final QueryParser.query_return query() throws RecognitionException {
		QueryParser.query_return retval = new QueryParser.query_return();
		retval.start = input.LT(1);

		Object root_0 = null;

		ParserRuleReturnScope conditionOr1 =null;


		try {
			// antlr3/com/google/gerrit/index/query/Query.g:93:3: ( conditionOr )
			// antlr3/com/google/gerrit/index/query/Query.g:93:5: conditionOr
			{
			root_0 = (Object)adaptor.nil();


			pushFollow(FOLLOW_conditionOr_in_query101);
			conditionOr1=conditionOr();
			state._fsp--;
			if (state.failed) return retval;
			if ( state.backtracking==0 ) adaptor.addChild(root_0, conditionOr1.getTree());

			}

			retval.stop = input.LT(-1);

			if ( state.backtracking==0 ) {
			retval.tree = (Object)adaptor.rulePostProcessing(root_0);
			adaptor.setTokenBoundaries(retval.tree, retval.start, retval.stop);
			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
			retval.tree = (Object)adaptor.errorNode(input, retval.start, input.LT(-1), re);
		}
		finally {
			// do for sure before leaving
		}
		return retval;
	}
	// $ANTLR end "query"


	public static class conditionOr_return extends ParserRuleReturnScope {
		Object tree;
		@Override
		public Object getTree() { return tree; }
	};


	// $ANTLR start "conditionOr"
	// antlr3/com/google/gerrit/index/query/Query.g:96:1: conditionOr : ( ( conditionAnd OR )=> conditionAnd OR ^ conditionAnd ( OR ! conditionAnd )* | conditionAnd );
	public final QueryParser.conditionOr_return conditionOr() throws RecognitionException {
		QueryParser.conditionOr_return retval = new QueryParser.conditionOr_return();
		retval.start = input.LT(1);

		Object root_0 = null;

		Token OR3=null;
		Token OR5=null;
		ParserRuleReturnScope conditionAnd2 =null;
		ParserRuleReturnScope conditionAnd4 =null;
		ParserRuleReturnScope conditionAnd6 =null;
		ParserRuleReturnScope conditionAnd7 =null;

		Object OR3_tree=null;
		Object OR5_tree=null;

		try {
			// antlr3/com/google/gerrit/index/query/Query.g:97:3: ( ( conditionAnd OR )=> conditionAnd OR ^ conditionAnd ( OR ! conditionAnd )* | conditionAnd )
			int alt2=2;
			switch ( input.LA(1) ) {
			case 15:
				{
				int LA2_1 = input.LA(2);
				if ( (synpred1_Query()) ) {
					alt2=1;
				}
				else if ( (true) ) {
					alt2=2;
				}

				}
				break;
			case NOT:
				{
				int LA2_2 = input.LA(2);
				if ( (synpred1_Query()) ) {
					alt2=1;
				}
				else if ( (true) ) {
					alt2=2;
				}

				}
				break;
			case 13:
				{
				int LA2_3 = input.LA(2);
				if ( (synpred1_Query()) ) {
					alt2=1;
				}
				else if ( (true) ) {
					alt2=2;
				}

				}
				break;
			case FIELD_NAME:
				{
				int LA2_4 = input.LA(2);
				if ( (synpred1_Query()) ) {
					alt2=1;
				}
				else if ( (true) ) {
					alt2=2;
				}

				}
				break;
			case SINGLE_WORD:
				{
				int LA2_5 = input.LA(2);
				if ( (synpred1_Query()) ) {
					alt2=1;
				}
				else if ( (true) ) {
					alt2=2;
				}

				}
				break;
			case EXACT_PHRASE:
				{
				int LA2_6 = input.LA(2);
				if ( (synpred1_Query()) ) {
					alt2=1;
				}
				else if ( (true) ) {
					alt2=2;
				}

				}
				break;
			default:
				if (state.backtracking>0) {state.failed=true; return retval;}
				NoViableAltException nvae =
					new NoViableAltException("", 2, 0, input);
				throw nvae;
			}
			switch (alt2) {
				case 1 :
					// antlr3/com/google/gerrit/index/query/Query.g:97:5: ( conditionAnd OR )=> conditionAnd OR ^ conditionAnd ( OR ! conditionAnd )*
					{
					root_0 = (Object)adaptor.nil();


					pushFollow(FOLLOW_conditionAnd_in_conditionOr126);
					conditionAnd2=conditionAnd();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) adaptor.addChild(root_0, conditionAnd2.getTree());

					OR3=(Token)match(input,OR,FOLLOW_OR_in_conditionOr128); if (state.failed) return retval;
					if ( state.backtracking==0 ) {
					OR3_tree = (Object)adaptor.create(OR3);
					root_0 = (Object)adaptor.becomeRoot(OR3_tree, root_0);
					}

					pushFollow(FOLLOW_conditionAnd_in_conditionOr131);
					conditionAnd4=conditionAnd();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) adaptor.addChild(root_0, conditionAnd4.getTree());

					// antlr3/com/google/gerrit/index/query/Query.g:98:38: ( OR ! conditionAnd )*
					loop1:
					while (true) {
						int alt1=2;
						int LA1_0 = input.LA(1);
						if ( (LA1_0==OR) ) {
							alt1=1;
						}

						switch (alt1) {
						case 1 :
							// antlr3/com/google/gerrit/index/query/Query.g:98:39: OR ! conditionAnd
							{
							OR5=(Token)match(input,OR,FOLLOW_OR_in_conditionOr134); if (state.failed) return retval;
							pushFollow(FOLLOW_conditionAnd_in_conditionOr137);
							conditionAnd6=conditionAnd();
							state._fsp--;
							if (state.failed) return retval;
							if ( state.backtracking==0 ) adaptor.addChild(root_0, conditionAnd6.getTree());

							}
							break;

						default :
							break loop1;
						}
					}

					}
					break;
				case 2 :
					// antlr3/com/google/gerrit/index/query/Query.g:99:5: conditionAnd
					{
					root_0 = (Object)adaptor.nil();


					pushFollow(FOLLOW_conditionAnd_in_conditionOr145);
					conditionAnd7=conditionAnd();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) adaptor.addChild(root_0, conditionAnd7.getTree());

					}
					break;

			}
			retval.stop = input.LT(-1);

			if ( state.backtracking==0 ) {
			retval.tree = (Object)adaptor.rulePostProcessing(root_0);
			adaptor.setTokenBoundaries(retval.tree, retval.start, retval.stop);
			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
			retval.tree = (Object)adaptor.errorNode(input, retval.start, input.LT(-1), re);
		}
		finally {
			// do for sure before leaving
		}
		return retval;
	}
	// $ANTLR end "conditionOr"


	public static class conditionAnd_return extends ParserRuleReturnScope {
		Object tree;
		@Override
		public Object getTree() { return tree; }
	};


	// $ANTLR start "conditionAnd"
	// antlr3/com/google/gerrit/index/query/Query.g:102:1: conditionAnd : ( ( conditionNot AND )=>i+= conditionNot (i+= conditionAnd2 )* -> ^( AND ( $i)+ ) | ( conditionNot conditionNot )=>i+= conditionNot (i+= conditionAnd2 )* -> ^( AND ( $i)+ ) | conditionNot );
	public final QueryParser.conditionAnd_return conditionAnd() throws RecognitionException {
		QueryParser.conditionAnd_return retval = new QueryParser.conditionAnd_return();
		retval.start = input.LT(1);

		Object root_0 = null;

		List list_i=null;
		ParserRuleReturnScope conditionNot8 =null;
		RuleReturnScope i = null;
		RewriteRuleSubtreeStream stream_conditionAnd2=new RewriteRuleSubtreeStream(adaptor,"rule conditionAnd2");
		RewriteRuleSubtreeStream stream_conditionNot=new RewriteRuleSubtreeStream(adaptor,"rule conditionNot");

		try {
			// antlr3/com/google/gerrit/index/query/Query.g:103:3: ( ( conditionNot AND )=>i+= conditionNot (i+= conditionAnd2 )* -> ^( AND ( $i)+ ) | ( conditionNot conditionNot )=>i+= conditionNot (i+= conditionAnd2 )* -> ^( AND ( $i)+ ) | conditionNot )
			int alt5=3;
			switch ( input.LA(1) ) {
			case 15:
				{
				int LA5_1 = input.LA(2);
				if ( (synpred2_Query()) ) {
					alt5=1;
				}
				else if ( (synpred3_Query()) ) {
					alt5=2;
				}
				else if ( (true) ) {
					alt5=3;
				}

				}
				break;
			case NOT:
				{
				int LA5_2 = input.LA(2);
				if ( (synpred2_Query()) ) {
					alt5=1;
				}
				else if ( (synpred3_Query()) ) {
					alt5=2;
				}
				else if ( (true) ) {
					alt5=3;
				}

				}
				break;
			case 13:
				{
				int LA5_3 = input.LA(2);
				if ( (synpred2_Query()) ) {
					alt5=1;
				}
				else if ( (synpred3_Query()) ) {
					alt5=2;
				}
				else if ( (true) ) {
					alt5=3;
				}

				}
				break;
			case FIELD_NAME:
				{
				int LA5_4 = input.LA(2);
				if ( (synpred2_Query()) ) {
					alt5=1;
				}
				else if ( (synpred3_Query()) ) {
					alt5=2;
				}
				else if ( (true) ) {
					alt5=3;
				}

				}
				break;
			case SINGLE_WORD:
				{
				int LA5_5 = input.LA(2);
				if ( (synpred2_Query()) ) {
					alt5=1;
				}
				else if ( (synpred3_Query()) ) {
					alt5=2;
				}
				else if ( (true) ) {
					alt5=3;
				}

				}
				break;
			case EXACT_PHRASE:
				{
				int LA5_6 = input.LA(2);
				if ( (synpred2_Query()) ) {
					alt5=1;
				}
				else if ( (synpred3_Query()) ) {
					alt5=2;
				}
				else if ( (true) ) {
					alt5=3;
				}

				}
				break;
			default:
				if (state.backtracking>0) {state.failed=true; return retval;}
				NoViableAltException nvae =
					new NoViableAltException("", 5, 0, input);
				throw nvae;
			}
			switch (alt5) {
				case 1 :
					// antlr3/com/google/gerrit/index/query/Query.g:103:5: ( conditionNot AND )=>i+= conditionNot (i+= conditionAnd2 )*
					{
					pushFollow(FOLLOW_conditionNot_in_conditionAnd172);
					i=conditionNot();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) stream_conditionNot.add(i.getTree());
					if (list_i==null) list_i=new ArrayList();
					list_i.add(i.getTree());
					// antlr3/com/google/gerrit/index/query/Query.g:104:24: (i+= conditionAnd2 )*
					loop3:
					while (true) {
						int alt3=2;
						int LA3_0 = input.LA(1);
						if ( (LA3_0==AND||(LA3_0 >= EXACT_PHRASE && LA3_0 <= FIELD_NAME)||LA3_0==NOT||LA3_0==SINGLE_WORD||LA3_0==13||LA3_0==15) ) {
							alt3=1;
						}

						switch (alt3) {
						case 1 :
							// antlr3/com/google/gerrit/index/query/Query.g:104:25: i+= conditionAnd2
							{
							pushFollow(FOLLOW_conditionAnd2_in_conditionAnd177);
							i=conditionAnd2();
							state._fsp--;
							if (state.failed) return retval;
							if ( state.backtracking==0 ) stream_conditionAnd2.add(i.getTree());
							if (list_i==null) list_i=new ArrayList();
							list_i.add(i.getTree());
							}
							break;

						default :
							break loop3;
						}
					}

					// AST REWRITE
					// elements: i
					// token labels: 
					// rule labels: retval
					// token list labels: 
					// rule list labels: i
					// wildcard labels: 
					if ( state.backtracking==0 ) {
					retval.tree = root_0;
					RewriteRuleSubtreeStream stream_retval=new RewriteRuleSubtreeStream(adaptor,"rule retval",retval!=null?retval.getTree():null);
					RewriteRuleSubtreeStream stream_i=new RewriteRuleSubtreeStream(adaptor,"token i",list_i);
					root_0 = (Object)adaptor.nil();
					// 105:5: -> ^( AND ( $i)+ )
					{
						// antlr3/com/google/gerrit/index/query/Query.g:105:8: ^( AND ( $i)+ )
						{
						Object root_1 = (Object)adaptor.nil();
						root_1 = (Object)adaptor.becomeRoot((Object)adaptor.create(AND, "AND"), root_1);
						if ( !(stream_i.hasNext()) ) {
							throw new RewriteEarlyExitException();
						}
						while ( stream_i.hasNext() ) {
							adaptor.addChild(root_1, stream_i.nextTree());
						}
						stream_i.reset();

						adaptor.addChild(root_0, root_1);
						}

					}


					retval.tree = root_0;
					}

					}
					break;
				case 2 :
					// antlr3/com/google/gerrit/index/query/Query.g:106:5: ( conditionNot conditionNot )=>i+= conditionNot (i+= conditionAnd2 )*
					{
					pushFollow(FOLLOW_conditionNot_in_conditionAnd213);
					i=conditionNot();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) stream_conditionNot.add(i.getTree());
					if (list_i==null) list_i=new ArrayList();
					list_i.add(i.getTree());
					// antlr3/com/google/gerrit/index/query/Query.g:107:24: (i+= conditionAnd2 )*
					loop4:
					while (true) {
						int alt4=2;
						int LA4_0 = input.LA(1);
						if ( (LA4_0==AND||(LA4_0 >= EXACT_PHRASE && LA4_0 <= FIELD_NAME)||LA4_0==NOT||LA4_0==SINGLE_WORD||LA4_0==13||LA4_0==15) ) {
							alt4=1;
						}

						switch (alt4) {
						case 1 :
							// antlr3/com/google/gerrit/index/query/Query.g:107:25: i+= conditionAnd2
							{
							pushFollow(FOLLOW_conditionAnd2_in_conditionAnd218);
							i=conditionAnd2();
							state._fsp--;
							if (state.failed) return retval;
							if ( state.backtracking==0 ) stream_conditionAnd2.add(i.getTree());
							if (list_i==null) list_i=new ArrayList();
							list_i.add(i.getTree());
							}
							break;

						default :
							break loop4;
						}
					}

					// AST REWRITE
					// elements: i
					// token labels: 
					// rule labels: retval
					// token list labels: 
					// rule list labels: i
					// wildcard labels: 
					if ( state.backtracking==0 ) {
					retval.tree = root_0;
					RewriteRuleSubtreeStream stream_retval=new RewriteRuleSubtreeStream(adaptor,"rule retval",retval!=null?retval.getTree():null);
					RewriteRuleSubtreeStream stream_i=new RewriteRuleSubtreeStream(adaptor,"token i",list_i);
					root_0 = (Object)adaptor.nil();
					// 108:5: -> ^( AND ( $i)+ )
					{
						// antlr3/com/google/gerrit/index/query/Query.g:108:8: ^( AND ( $i)+ )
						{
						Object root_1 = (Object)adaptor.nil();
						root_1 = (Object)adaptor.becomeRoot((Object)adaptor.create(AND, "AND"), root_1);
						if ( !(stream_i.hasNext()) ) {
							throw new RewriteEarlyExitException();
						}
						while ( stream_i.hasNext() ) {
							adaptor.addChild(root_1, stream_i.nextTree());
						}
						stream_i.reset();

						adaptor.addChild(root_0, root_1);
						}

					}


					retval.tree = root_0;
					}

					}
					break;
				case 3 :
					// antlr3/com/google/gerrit/index/query/Query.g:109:5: conditionNot
					{
					root_0 = (Object)adaptor.nil();


					pushFollow(FOLLOW_conditionNot_in_conditionAnd240);
					conditionNot8=conditionNot();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) adaptor.addChild(root_0, conditionNot8.getTree());

					}
					break;

			}
			retval.stop = input.LT(-1);

			if ( state.backtracking==0 ) {
			retval.tree = (Object)adaptor.rulePostProcessing(root_0);
			adaptor.setTokenBoundaries(retval.tree, retval.start, retval.stop);
			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
			retval.tree = (Object)adaptor.errorNode(input, retval.start, input.LT(-1), re);
		}
		finally {
			// do for sure before leaving
		}
		return retval;
	}
	// $ANTLR end "conditionAnd"


	public static class conditionAnd2_return extends ParserRuleReturnScope {
		Object tree;
		@Override
		public Object getTree() { return tree; }
	};


	// $ANTLR start "conditionAnd2"
	// antlr3/com/google/gerrit/index/query/Query.g:111:1: conditionAnd2 : ( AND ! conditionNot | conditionNot );
	public final QueryParser.conditionAnd2_return conditionAnd2() throws RecognitionException {
		QueryParser.conditionAnd2_return retval = new QueryParser.conditionAnd2_return();
		retval.start = input.LT(1);

		Object root_0 = null;

		Token AND9=null;
		ParserRuleReturnScope conditionNot10 =null;
		ParserRuleReturnScope conditionNot11 =null;

		Object AND9_tree=null;

		try {
			// antlr3/com/google/gerrit/index/query/Query.g:112:3: ( AND ! conditionNot | conditionNot )
			int alt6=2;
			int LA6_0 = input.LA(1);
			if ( (LA6_0==AND) ) {
				alt6=1;
			}
			else if ( ((LA6_0 >= EXACT_PHRASE && LA6_0 <= FIELD_NAME)||LA6_0==NOT||LA6_0==SINGLE_WORD||LA6_0==13||LA6_0==15) ) {
				alt6=2;
			}

			else {
				if (state.backtracking>0) {state.failed=true; return retval;}
				NoViableAltException nvae =
					new NoViableAltException("", 6, 0, input);
				throw nvae;
			}

			switch (alt6) {
				case 1 :
					// antlr3/com/google/gerrit/index/query/Query.g:112:5: AND ! conditionNot
					{
					root_0 = (Object)adaptor.nil();


					AND9=(Token)match(input,AND,FOLLOW_AND_in_conditionAnd2252); if (state.failed) return retval;
					pushFollow(FOLLOW_conditionNot_in_conditionAnd2255);
					conditionNot10=conditionNot();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) adaptor.addChild(root_0, conditionNot10.getTree());

					}
					break;
				case 2 :
					// antlr3/com/google/gerrit/index/query/Query.g:113:5: conditionNot
					{
					root_0 = (Object)adaptor.nil();


					pushFollow(FOLLOW_conditionNot_in_conditionAnd2261);
					conditionNot11=conditionNot();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) adaptor.addChild(root_0, conditionNot11.getTree());

					}
					break;

			}
			retval.stop = input.LT(-1);

			if ( state.backtracking==0 ) {
			retval.tree = (Object)adaptor.rulePostProcessing(root_0);
			adaptor.setTokenBoundaries(retval.tree, retval.start, retval.stop);
			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
			retval.tree = (Object)adaptor.errorNode(input, retval.start, input.LT(-1), re);
		}
		finally {
			// do for sure before leaving
		}
		return retval;
	}
	// $ANTLR end "conditionAnd2"


	public static class conditionNot_return extends ParserRuleReturnScope {
		Object tree;
		@Override
		public Object getTree() { return tree; }
	};


	// $ANTLR start "conditionNot"
	// antlr3/com/google/gerrit/index/query/Query.g:116:1: conditionNot : ( '-' conditionBase -> ^( NOT conditionBase ) | NOT ^ conditionBase | conditionBase );
	public final QueryParser.conditionNot_return conditionNot() throws RecognitionException {
		QueryParser.conditionNot_return retval = new QueryParser.conditionNot_return();
		retval.start = input.LT(1);

		Object root_0 = null;

		Token char_literal12=null;
		Token NOT14=null;
		ParserRuleReturnScope conditionBase13 =null;
		ParserRuleReturnScope conditionBase15 =null;
		ParserRuleReturnScope conditionBase16 =null;

		Object char_literal12_tree=null;
		Object NOT14_tree=null;
		RewriteRuleTokenStream stream_15=new RewriteRuleTokenStream(adaptor,"token 15");
		RewriteRuleSubtreeStream stream_conditionBase=new RewriteRuleSubtreeStream(adaptor,"rule conditionBase");

		try {
			// antlr3/com/google/gerrit/index/query/Query.g:117:3: ( '-' conditionBase -> ^( NOT conditionBase ) | NOT ^ conditionBase | conditionBase )
			int alt7=3;
			switch ( input.LA(1) ) {
			case 15:
				{
				alt7=1;
				}
				break;
			case NOT:
				{
				alt7=2;
				}
				break;
			case EXACT_PHRASE:
			case FIELD_NAME:
			case SINGLE_WORD:
			case 13:
				{
				alt7=3;
				}
				break;
			default:
				if (state.backtracking>0) {state.failed=true; return retval;}
				NoViableAltException nvae =
					new NoViableAltException("", 7, 0, input);
				throw nvae;
			}
			switch (alt7) {
				case 1 :
					// antlr3/com/google/gerrit/index/query/Query.g:117:5: '-' conditionBase
					{
					char_literal12=(Token)match(input,15,FOLLOW_15_in_conditionNot274); if (state.failed) return retval; 
					if ( state.backtracking==0 ) stream_15.add(char_literal12);

					pushFollow(FOLLOW_conditionBase_in_conditionNot276);
					conditionBase13=conditionBase();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) stream_conditionBase.add(conditionBase13.getTree());
					// AST REWRITE
					// elements: conditionBase
					// token labels: 
					// rule labels: retval
					// token list labels: 
					// rule list labels: 
					// wildcard labels: 
					if ( state.backtracking==0 ) {
					retval.tree = root_0;
					RewriteRuleSubtreeStream stream_retval=new RewriteRuleSubtreeStream(adaptor,"rule retval",retval!=null?retval.getTree():null);

					root_0 = (Object)adaptor.nil();
					// 117:23: -> ^( NOT conditionBase )
					{
						// antlr3/com/google/gerrit/index/query/Query.g:117:26: ^( NOT conditionBase )
						{
						Object root_1 = (Object)adaptor.nil();
						root_1 = (Object)adaptor.becomeRoot((Object)adaptor.create(NOT, "NOT"), root_1);
						adaptor.addChild(root_1, stream_conditionBase.nextTree());
						adaptor.addChild(root_0, root_1);
						}

					}


					retval.tree = root_0;
					}

					}
					break;
				case 2 :
					// antlr3/com/google/gerrit/index/query/Query.g:118:5: NOT ^ conditionBase
					{
					root_0 = (Object)adaptor.nil();


					NOT14=(Token)match(input,NOT,FOLLOW_NOT_in_conditionNot290); if (state.failed) return retval;
					if ( state.backtracking==0 ) {
					NOT14_tree = (Object)adaptor.create(NOT14);
					root_0 = (Object)adaptor.becomeRoot(NOT14_tree, root_0);
					}

					pushFollow(FOLLOW_conditionBase_in_conditionNot293);
					conditionBase15=conditionBase();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) adaptor.addChild(root_0, conditionBase15.getTree());

					}
					break;
				case 3 :
					// antlr3/com/google/gerrit/index/query/Query.g:119:5: conditionBase
					{
					root_0 = (Object)adaptor.nil();


					pushFollow(FOLLOW_conditionBase_in_conditionNot299);
					conditionBase16=conditionBase();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) adaptor.addChild(root_0, conditionBase16.getTree());

					}
					break;

			}
			retval.stop = input.LT(-1);

			if ( state.backtracking==0 ) {
			retval.tree = (Object)adaptor.rulePostProcessing(root_0);
			adaptor.setTokenBoundaries(retval.tree, retval.start, retval.stop);
			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
			retval.tree = (Object)adaptor.errorNode(input, retval.start, input.LT(-1), re);
		}
		finally {
			// do for sure before leaving
		}
		return retval;
	}
	// $ANTLR end "conditionNot"


	public static class conditionBase_return extends ParserRuleReturnScope {
		Object tree;
		@Override
		public Object getTree() { return tree; }
	};


	// $ANTLR start "conditionBase"
	// antlr3/com/google/gerrit/index/query/Query.g:121:1: conditionBase : ( '(' ! conditionOr ')' !| ( FIELD_NAME ':' )=> FIELD_NAME ^ ':' ! fieldValue | fieldValue -> ^( DEFAULT_FIELD fieldValue ) );
	public final QueryParser.conditionBase_return conditionBase() throws RecognitionException {
		QueryParser.conditionBase_return retval = new QueryParser.conditionBase_return();
		retval.start = input.LT(1);

		Object root_0 = null;

		Token char_literal17=null;
		Token char_literal19=null;
		Token FIELD_NAME20=null;
		Token char_literal21=null;
		ParserRuleReturnScope conditionOr18 =null;
		ParserRuleReturnScope fieldValue22 =null;
		ParserRuleReturnScope fieldValue23 =null;

		Object char_literal17_tree=null;
		Object char_literal19_tree=null;
		Object FIELD_NAME20_tree=null;
		Object char_literal21_tree=null;
		RewriteRuleSubtreeStream stream_fieldValue=new RewriteRuleSubtreeStream(adaptor,"rule fieldValue");

		try {
			// antlr3/com/google/gerrit/index/query/Query.g:122:3: ( '(' ! conditionOr ')' !| ( FIELD_NAME ':' )=> FIELD_NAME ^ ':' ! fieldValue | fieldValue -> ^( DEFAULT_FIELD fieldValue ) )
			int alt8=3;
			switch ( input.LA(1) ) {
			case 13:
				{
				alt8=1;
				}
				break;
			case FIELD_NAME:
				{
				int LA8_2 = input.LA(2);
				if ( (LA8_2==16) && (synpred4_Query())) {
					alt8=2;
				}
				else if ( (LA8_2==EOF||LA8_2==AND||(LA8_2 >= EXACT_PHRASE && LA8_2 <= FIELD_NAME)||(LA8_2 >= NOT && LA8_2 <= SINGLE_WORD)||(LA8_2 >= 13 && LA8_2 <= 15)) ) {
					alt8=3;
				}

				else {
					if (state.backtracking>0) {state.failed=true; return retval;}
					int nvaeMark = input.mark();
					try {
						input.consume();
						NoViableAltException nvae =
							new NoViableAltException("", 8, 2, input);
						throw nvae;
					} finally {
						input.rewind(nvaeMark);
					}
				}

				}
				break;
			case EXACT_PHRASE:
			case SINGLE_WORD:
				{
				alt8=3;
				}
				break;
			default:
				if (state.backtracking>0) {state.failed=true; return retval;}
				NoViableAltException nvae =
					new NoViableAltException("", 8, 0, input);
				throw nvae;
			}
			switch (alt8) {
				case 1 :
					// antlr3/com/google/gerrit/index/query/Query.g:122:5: '(' ! conditionOr ')' !
					{
					root_0 = (Object)adaptor.nil();


					char_literal17=(Token)match(input,13,FOLLOW_13_in_conditionBase311); if (state.failed) return retval;
					pushFollow(FOLLOW_conditionOr_in_conditionBase314);
					conditionOr18=conditionOr();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) adaptor.addChild(root_0, conditionOr18.getTree());

					char_literal19=(Token)match(input,14,FOLLOW_14_in_conditionBase316); if (state.failed) return retval;
					}
					break;
				case 2 :
					// antlr3/com/google/gerrit/index/query/Query.g:123:5: ( FIELD_NAME ':' )=> FIELD_NAME ^ ':' ! fieldValue
					{
					root_0 = (Object)adaptor.nil();


					FIELD_NAME20=(Token)match(input,FIELD_NAME,FOLLOW_FIELD_NAME_in_conditionBase331); if (state.failed) return retval;
					if ( state.backtracking==0 ) {
					FIELD_NAME20_tree = (Object)adaptor.create(FIELD_NAME20);
					root_0 = (Object)adaptor.becomeRoot(FIELD_NAME20_tree, root_0);
					}

					char_literal21=(Token)match(input,16,FOLLOW_16_in_conditionBase334); if (state.failed) return retval;
					pushFollow(FOLLOW_fieldValue_in_conditionBase337);
					fieldValue22=fieldValue();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) adaptor.addChild(root_0, fieldValue22.getTree());

					}
					break;
				case 3 :
					// antlr3/com/google/gerrit/index/query/Query.g:124:5: fieldValue
					{
					pushFollow(FOLLOW_fieldValue_in_conditionBase343);
					fieldValue23=fieldValue();
					state._fsp--;
					if (state.failed) return retval;
					if ( state.backtracking==0 ) stream_fieldValue.add(fieldValue23.getTree());
					// AST REWRITE
					// elements: fieldValue
					// token labels: 
					// rule labels: retval
					// token list labels: 
					// rule list labels: 
					// wildcard labels: 
					if ( state.backtracking==0 ) {
					retval.tree = root_0;
					RewriteRuleSubtreeStream stream_retval=new RewriteRuleSubtreeStream(adaptor,"rule retval",retval!=null?retval.getTree():null);

					root_0 = (Object)adaptor.nil();
					// 124:16: -> ^( DEFAULT_FIELD fieldValue )
					{
						// antlr3/com/google/gerrit/index/query/Query.g:124:19: ^( DEFAULT_FIELD fieldValue )
						{
						Object root_1 = (Object)adaptor.nil();
						root_1 = (Object)adaptor.becomeRoot((Object)adaptor.create(DEFAULT_FIELD, "DEFAULT_FIELD"), root_1);
						adaptor.addChild(root_1, stream_fieldValue.nextTree());
						adaptor.addChild(root_0, root_1);
						}

					}


					retval.tree = root_0;
					}

					}
					break;

			}
			retval.stop = input.LT(-1);

			if ( state.backtracking==0 ) {
			retval.tree = (Object)adaptor.rulePostProcessing(root_0);
			adaptor.setTokenBoundaries(retval.tree, retval.start, retval.stop);
			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
			retval.tree = (Object)adaptor.errorNode(input, retval.start, input.LT(-1), re);
		}
		finally {
			// do for sure before leaving
		}
		return retval;
	}
	// $ANTLR end "conditionBase"


	public static class fieldValue_return extends ParserRuleReturnScope {
		Object tree;
		@Override
		public Object getTree() { return tree; }
	};


	// $ANTLR start "fieldValue"
	// antlr3/com/google/gerrit/index/query/Query.g:127:1: fieldValue : (n= FIELD_NAME -> SINGLE_WORD[n] | SINGLE_WORD | EXACT_PHRASE );
	public final QueryParser.fieldValue_return fieldValue() throws RecognitionException {
		QueryParser.fieldValue_return retval = new QueryParser.fieldValue_return();
		retval.start = input.LT(1);

		Object root_0 = null;

		Token n=null;
		Token SINGLE_WORD24=null;
		Token EXACT_PHRASE25=null;

		Object n_tree=null;
		Object SINGLE_WORD24_tree=null;
		Object EXACT_PHRASE25_tree=null;
		RewriteRuleTokenStream stream_FIELD_NAME=new RewriteRuleTokenStream(adaptor,"token FIELD_NAME");

		try {
			// antlr3/com/google/gerrit/index/query/Query.g:128:3: (n= FIELD_NAME -> SINGLE_WORD[n] | SINGLE_WORD | EXACT_PHRASE )
			int alt9=3;
			switch ( input.LA(1) ) {
			case FIELD_NAME:
				{
				alt9=1;
				}
				break;
			case SINGLE_WORD:
				{
				alt9=2;
				}
				break;
			case EXACT_PHRASE:
				{
				alt9=3;
				}
				break;
			default:
				if (state.backtracking>0) {state.failed=true; return retval;}
				NoViableAltException nvae =
					new NoViableAltException("", 9, 0, input);
				throw nvae;
			}
			switch (alt9) {
				case 1 :
					// antlr3/com/google/gerrit/index/query/Query.g:128:5: n= FIELD_NAME
					{
					n=(Token)match(input,FIELD_NAME,FOLLOW_FIELD_NAME_in_fieldValue366); if (state.failed) return retval; 
					if ( state.backtracking==0 ) stream_FIELD_NAME.add(n);

					// AST REWRITE
					// elements: 
					// token labels: 
					// rule labels: retval
					// token list labels: 
					// rule list labels: 
					// wildcard labels: 
					if ( state.backtracking==0 ) {
					retval.tree = root_0;
					RewriteRuleSubtreeStream stream_retval=new RewriteRuleSubtreeStream(adaptor,"rule retval",retval!=null?retval.getTree():null);

					root_0 = (Object)adaptor.nil();
					// 128:20: -> SINGLE_WORD[n]
					{
						adaptor.addChild(root_0, (Object)adaptor.create(SINGLE_WORD, n));
					}


					retval.tree = root_0;
					}

					}
					break;
				case 2 :
					// antlr3/com/google/gerrit/index/query/Query.g:129:5: SINGLE_WORD
					{
					root_0 = (Object)adaptor.nil();


					SINGLE_WORD24=(Token)match(input,SINGLE_WORD,FOLLOW_SINGLE_WORD_in_fieldValue379); if (state.failed) return retval;
					if ( state.backtracking==0 ) {
					SINGLE_WORD24_tree = (Object)adaptor.create(SINGLE_WORD24);
					adaptor.addChild(root_0, SINGLE_WORD24_tree);
					}

					}
					break;
				case 3 :
					// antlr3/com/google/gerrit/index/query/Query.g:130:5: EXACT_PHRASE
					{
					root_0 = (Object)adaptor.nil();


					EXACT_PHRASE25=(Token)match(input,EXACT_PHRASE,FOLLOW_EXACT_PHRASE_in_fieldValue385); if (state.failed) return retval;
					if ( state.backtracking==0 ) {
					EXACT_PHRASE25_tree = (Object)adaptor.create(EXACT_PHRASE25);
					adaptor.addChild(root_0, EXACT_PHRASE25_tree);
					}

					}
					break;

			}
			retval.stop = input.LT(-1);

			if ( state.backtracking==0 ) {
			retval.tree = (Object)adaptor.rulePostProcessing(root_0);
			adaptor.setTokenBoundaries(retval.tree, retval.start, retval.stop);
			}
		}
		catch (RecognitionException re) {
			reportError(re);
			recover(input,re);
			retval.tree = (Object)adaptor.errorNode(input, retval.start, input.LT(-1), re);
		}
		finally {
			// do for sure before leaving
		}
		return retval;
	}
	// $ANTLR end "fieldValue"

	// $ANTLR start synpred1_Query
	public final void synpred1_Query_fragment() throws RecognitionException {
		// antlr3/com/google/gerrit/index/query/Query.g:97:5: ( conditionAnd OR )
		// antlr3/com/google/gerrit/index/query/Query.g:97:6: conditionAnd OR
		{
		pushFollow(FOLLOW_conditionAnd_in_synpred1_Query115);
		conditionAnd();
		state._fsp--;
		if (state.failed) return;

		match(input,OR,FOLLOW_OR_in_synpred1_Query117); if (state.failed) return;

		}

	}
	// $ANTLR end synpred1_Query

	// $ANTLR start synpred2_Query
	public final void synpred2_Query_fragment() throws RecognitionException {
		// antlr3/com/google/gerrit/index/query/Query.g:103:5: ( conditionNot AND )
		// antlr3/com/google/gerrit/index/query/Query.g:103:6: conditionNot AND
		{
		pushFollow(FOLLOW_conditionNot_in_synpred2_Query159);
		conditionNot();
		state._fsp--;
		if (state.failed) return;

		match(input,AND,FOLLOW_AND_in_synpred2_Query161); if (state.failed) return;

		}

	}
	// $ANTLR end synpred2_Query

	// $ANTLR start synpred3_Query
	public final void synpred3_Query_fragment() throws RecognitionException {
		// antlr3/com/google/gerrit/index/query/Query.g:106:5: ( conditionNot conditionNot )
		// antlr3/com/google/gerrit/index/query/Query.g:106:6: conditionNot conditionNot
		{
		pushFollow(FOLLOW_conditionNot_in_synpred3_Query200);
		conditionNot();
		state._fsp--;
		if (state.failed) return;

		pushFollow(FOLLOW_conditionNot_in_synpred3_Query202);
		conditionNot();
		state._fsp--;
		if (state.failed) return;

		}

	}
	// $ANTLR end synpred3_Query

	// $ANTLR start synpred4_Query
	public final void synpred4_Query_fragment() throws RecognitionException {
		// antlr3/com/google/gerrit/index/query/Query.g:123:5: ( FIELD_NAME ':' )
		// antlr3/com/google/gerrit/index/query/Query.g:123:6: FIELD_NAME ':'
		{
		match(input,FIELD_NAME,FOLLOW_FIELD_NAME_in_synpred4_Query324); if (state.failed) return;

		match(input,16,FOLLOW_16_in_synpred4_Query326); if (state.failed) return;

		}

	}
	// $ANTLR end synpred4_Query

	// Delegated rules

	public final boolean synpred3_Query() {
		state.backtracking++;
		int start = input.mark();
		try {
			synpred3_Query_fragment(); // can never throw exception
		} catch (RecognitionException re) {
			System.err.println("impossible: "+re);
		}
		boolean success = !state.failed;
		input.rewind(start);
		state.backtracking--;
		state.failed=false;
		return success;
	}
	public final boolean synpred1_Query() {
		state.backtracking++;
		int start = input.mark();
		try {
			synpred1_Query_fragment(); // can never throw exception
		} catch (RecognitionException re) {
			System.err.println("impossible: "+re);
		}
		boolean success = !state.failed;
		input.rewind(start);
		state.backtracking--;
		state.failed=false;
		return success;
	}
	public final boolean synpred4_Query() {
		state.backtracking++;
		int start = input.mark();
		try {
			synpred4_Query_fragment(); // can never throw exception
		} catch (RecognitionException re) {
			System.err.println("impossible: "+re);
		}
		boolean success = !state.failed;
		input.rewind(start);
		state.backtracking--;
		state.failed=false;
		return success;
	}
	public final boolean synpred2_Query() {
		state.backtracking++;
		int start = input.mark();
		try {
			synpred2_Query_fragment(); // can never throw exception
		} catch (RecognitionException re) {
			System.err.println("impossible: "+re);
		}
		boolean success = !state.failed;
		input.rewind(start);
		state.backtracking--;
		state.failed=false;
		return success;
	}



	public static final BitSet FOLLOW_conditionOr_in_query101 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_conditionAnd_in_conditionOr126 = new BitSet(new long[]{0x0000000000000400L});
	public static final BitSet FOLLOW_OR_in_conditionOr128 = new BitSet(new long[]{0x000000000000AAC0L});
	public static final BitSet FOLLOW_conditionAnd_in_conditionOr131 = new BitSet(new long[]{0x0000000000000402L});
	public static final BitSet FOLLOW_OR_in_conditionOr134 = new BitSet(new long[]{0x000000000000AAC0L});
	public static final BitSet FOLLOW_conditionAnd_in_conditionOr137 = new BitSet(new long[]{0x0000000000000402L});
	public static final BitSet FOLLOW_conditionAnd_in_conditionOr145 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_conditionNot_in_conditionAnd172 = new BitSet(new long[]{0x000000000000AAD2L});
	public static final BitSet FOLLOW_conditionAnd2_in_conditionAnd177 = new BitSet(new long[]{0x000000000000AAD2L});
	public static final BitSet FOLLOW_conditionNot_in_conditionAnd213 = new BitSet(new long[]{0x000000000000AAD2L});
	public static final BitSet FOLLOW_conditionAnd2_in_conditionAnd218 = new BitSet(new long[]{0x000000000000AAD2L});
	public static final BitSet FOLLOW_conditionNot_in_conditionAnd240 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_AND_in_conditionAnd2252 = new BitSet(new long[]{0x000000000000AAC0L});
	public static final BitSet FOLLOW_conditionNot_in_conditionAnd2255 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_conditionNot_in_conditionAnd2261 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_15_in_conditionNot274 = new BitSet(new long[]{0x00000000000028C0L});
	public static final BitSet FOLLOW_conditionBase_in_conditionNot276 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_NOT_in_conditionNot290 = new BitSet(new long[]{0x00000000000028C0L});
	public static final BitSet FOLLOW_conditionBase_in_conditionNot293 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_conditionBase_in_conditionNot299 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_13_in_conditionBase311 = new BitSet(new long[]{0x000000000000AAC0L});
	public static final BitSet FOLLOW_conditionOr_in_conditionBase314 = new BitSet(new long[]{0x0000000000004000L});
	public static final BitSet FOLLOW_14_in_conditionBase316 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_FIELD_NAME_in_conditionBase331 = new BitSet(new long[]{0x0000000000010000L});
	public static final BitSet FOLLOW_16_in_conditionBase334 = new BitSet(new long[]{0x00000000000008C0L});
	public static final BitSet FOLLOW_fieldValue_in_conditionBase337 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_fieldValue_in_conditionBase343 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_FIELD_NAME_in_fieldValue366 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_SINGLE_WORD_in_fieldValue379 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_EXACT_PHRASE_in_fieldValue385 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_conditionAnd_in_synpred1_Query115 = new BitSet(new long[]{0x0000000000000400L});
	public static final BitSet FOLLOW_OR_in_synpred1_Query117 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_conditionNot_in_synpred2_Query159 = new BitSet(new long[]{0x0000000000000010L});
	public static final BitSet FOLLOW_AND_in_synpred2_Query161 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_conditionNot_in_synpred3_Query200 = new BitSet(new long[]{0x000000000000AAC0L});
	public static final BitSet FOLLOW_conditionNot_in_synpred3_Query202 = new BitSet(new long[]{0x0000000000000002L});
	public static final BitSet FOLLOW_FIELD_NAME_in_synpred4_Query324 = new BitSet(new long[]{0x0000000000010000L});
	public static final BitSet FOLLOW_16_in_synpred4_Query326 = new BitSet(new long[]{0x0000000000000002L});
}