当前位置: 首页>>代码示例>>Java>>正文


Java Parser类代码示例

本文整理汇总了Java中org.codehaus.jparsec.Parser的典型用法代码示例。如果您正苦于以下问题:Java Parser类的具体用法?Java Parser怎么用?Java Parser使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。


Parser类属于org.codehaus.jparsec包,在下文中一共展示了Parser类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: enumMembersMany

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
public static Parser<List<EnumMemberExp>> enumMembersMany() {
       return enumMembers00().many().sepBy(term(","))
               .map(new org.codehaus.jparsec.functors.Map<List<List<EnumMemberExp>>, List<EnumMemberExp>>() {
                   @Override
                   public List<EnumMemberExp> map(List<List<EnumMemberExp>> arg0) {
					List<EnumMemberExp> cc = new ArrayList<>();
					for(List<EnumMemberExp> sub: arg0) {
						if (sub.size() > 1) {
							throw new IllegalArgumentException("Enum members must be separated by commas");
						}
						for(EnumMemberExp re: sub) {
							cc.add(re);
						}
					}
					return cc;
                   }
               });    
}
 
开发者ID:ianrae,项目名称:dnal-lang,代码行数:19,代码来源:TypeParser.java

示例2: packageDecl

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
public static Parser<PackageExp> packageDecl() {
    return Parsers.sequence(term("package"), VarParser.ident().many().sepBy(term(".")).
            map(new org.codehaus.jparsec.functors.Map<List<List<IdentExp>>, PackageExp>() {
                @Override
                public PackageExp map(List<List<IdentExp>> arg0) {
                    StringBuilder sb = new StringBuilder();
                    boolean flag = false;
                    if (! arg0.isEmpty()) {
                        for(List<IdentExp> sublist : arg0) {
                            if (! sublist.isEmpty()) {
                                if (flag) {
                                    sb.append('.');
                                }
                                sb.append(sublist.get(0).val);
                                flag = true;
                            }
                        }
                    }
                    return new PackageExp(sb.toString());
                }
            }));
}
 
开发者ID:ianrae,项目名称:dnal-lang,代码行数:23,代码来源:PackageParser.java

示例3: importDecl

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
public static Parser<ImportExp> importDecl() {
    return Parsers.sequence(term("import"), VarParser.ident().many().sepBy(term(".")).
            map(new org.codehaus.jparsec.functors.Map<List<List<IdentExp>>, ImportExp>() {
                @Override
                public ImportExp map(List<List<IdentExp>> arg0) {
                    StringBuilder sb = new StringBuilder();
                    boolean flag = false;
                    if (! arg0.isEmpty()) {
                        for(List<IdentExp> sublist : arg0) {
                            if (! sublist.isEmpty()) {
                                if (flag) {
                                    sb.append('.');
                                }
                                sb.append(sublist.get(0).val);
                                flag = true;
                            }
                        }
                    }
                    return new ImportExp(sb.toString());
                }
            }));
}
 
开发者ID:ianrae,项目名称:dnal-lang,代码行数:23,代码来源:PackageParser.java

示例4: structMembersMany

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
public static Parser<List<StructMemberExp>> structMembersMany() {
       return structMembers00().many().sepBy(term(","))
               .map(new org.codehaus.jparsec.functors.Map<List<List<StructMemberExp>>, List<StructMemberExp>>() {
                   @Override
                   public List<StructMemberExp> map(List<List<StructMemberExp>> arg0) {
					List<StructMemberExp> cc = new ArrayList<>();
					for(List<StructMemberExp> sub: arg0) {
						if (sub.size() > 1) {
							throw new IllegalArgumentException("Struct members must be separated by commas");
						}
						for(StructMemberExp re: sub) {
							cc.add(re);
						}
					}
					return cc;
                   }
               });    
}
 
开发者ID:ianrae,项目名称:dnal-lang,代码行数:19,代码来源:TypeParser.java

示例5: listvalueassign

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
public static Parser<ListAssignExp> listvalueassign() {
	return Parsers.between(term("["), listmemberRef.lazy().many().sepBy(term(",")), term("]")).
			map(new org.codehaus.jparsec.functors.Map<List<List<Exp>>, ListAssignExp>() {
				@Override
				public ListAssignExp map(List<List<Exp>> arg0) {
					List<Exp> list = new ArrayList<>();
					if (! arg0.isEmpty()) {
						for(List<Exp> sublist : arg0) {
							if (! sublist.isEmpty()) {
								list.add(sublist.get(0));
							}
						}
					}
					return new ListAssignExp(list);
				}
			});
}
 
开发者ID:ianrae,项目名称:dnal-lang,代码行数:18,代码来源:VarParser.java

示例6: structvalueassign

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
public static Parser<StructAssignExp> structvalueassign() {
	return Parsers.between(term("{"), 
			structmemberRef.lazy().many().sepBy(term(",")), term("}")).
			map(new org.codehaus.jparsec.functors.Map<List<List<Exp>>, StructAssignExp>() {
				@Override
				public StructAssignExp map(List<List<Exp>> arg0) {
					List<Exp> list = new ArrayList<>();
					for(List<Exp> sublist : arg0) {
						if (! sublist.isEmpty()) {
							list.add(sublist.get(0));
						}
					}
					return new StructAssignExp(list);
				}
			});
}
 
开发者ID:ianrae,项目名称:dnal-lang,代码行数:17,代码来源:VarParser.java

示例7: memberMany

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
public static Parser<List<ViewMemberExp>> memberMany() {
       return member().many().sepBy(term(","))
               .map(new org.codehaus.jparsec.functors.Map<List<List<ViewMemberExp>>, List<ViewMemberExp>>() {
                   @Override
                   public List<ViewMemberExp> map(List<List<ViewMemberExp>> arg0) {
					List<ViewMemberExp> cc = new ArrayList<>();
					for(List<ViewMemberExp> sub: arg0) {
						if (sub.size() > 1) {
							throw new IllegalArgumentException("View members must be separated by commas");
						}
						for(ViewMemberExp re: sub) {
							cc.add(re);
						}
					}
					return cc;
                   }
               });    
}
 
开发者ID:ianrae,项目名称:dnal-lang,代码行数:19,代码来源:ViewParser.java

示例8: ruleMany

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
public static Parser<List<RuleExp>> ruleMany() {
       return ruleExpr().many().sepBy(term(","))
               .map(new org.codehaus.jparsec.functors.Map<List<List<RuleExp>>, List<RuleExp>>() {
                   @Override
                   public List<RuleExp> map(List<List<RuleExp>> arg0) {
					List<RuleExp> cc = new ArrayList<>();
					for(List<RuleExp> sub: arg0) {
						if (sub.size() > 1) {
							throw new IllegalArgumentException("Rules must be separated by commas");
						}
						for(RuleExp re: sub) {
							cc.add(re);
						}
					}
					return cc;
                   }
               });    
}
 
开发者ID:ianrae,项目名称:dnal-lang,代码行数:19,代码来源:RuleParser.java

示例9: arithmetic

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
static Parser<Expression> arithmetic(Parser<Expression> atom) {
  Reference<Expression> reference = Parser.newReference();
  Parser<Expression> operand =
      Parsers.or(paren(reference.lazy()), functionCall(reference.lazy()), atom);
  Parser<Expression> parser = new OperatorTable<Expression>()
      .infixl(binary("/", Op.AGG_DIV), 5)
      .infixl(binary("<", Op.LESS), 7)
      .infixl(binary("<=", Op.LESS_EQ), 7)
      .infixl(binary("=", Op.EQ), 7)
      .infixl(binary("!=", Op.NOT_EQ), 7)
      .infixl(binary(">", Op.GREATER), 7)
      .infixl(binary(">=", Op.GREATER_EQ), 7)
      .infixl(binary("+", Op.PLUS), 10)
      .infixl(binary("-", Op.MINUS), 10)
      .infixl(binary("*", Op.MUL), 20)
      .infixl(binary("\\", Op.DIV), 20)
      .infixl(binary("%", Op.MOD), 20)
      .prefix(unary("-", Op.NEG), 30)
      .build(operand);
  reference.set(parser);
  return parser;
}
 
开发者ID:indeedeng,项目名称:iql,代码行数:23,代码来源:ExpressionParser.java

示例10: arrayClass

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
/**
 * Parser for internal array class names such as {@code [Z}, {@code [[[Ljava.lang.String;} etc.
 *
 * <p>.java files can only use {@code int[]} format, not the internal format. But we have to
 * be able to parse from internal format because {@link Type#toString} can produce it.
 */
private Parser<Class<?>> arrayClass() {
  Parser<Class<?>> arrayType = FQN.next(name -> {
      // Only invoked when we already see a "[" at the beginning.
      Class<?> primitiveArray = PRIMITIVE_ARRAY_TYPES.get("[" + name);
      if (primitiveArray != null) return Parsers.constant(primitiveArray);
      if (name.startsWith("L") && name.endsWith(";")) {
        String className = name.substring(1, name.length() - 1);
        return Parsers.constant(Types.newArrayType(loadClass(className)));
      } else {
        return Parsers.expect("array class internal name");
      }
    });
  return TERMS.token("[") // must be an array internal format from this point on.
      .next(arrayType.prefix(TERMS.token("[").retn(Types::newArrayType)));
}
 
开发者ID:jparsec,项目名称:jparsec-g,代码行数:22,代码来源:TypeParser.java

示例11: paren

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
static <T extends ExprNode> Parser<ExprNode> paren (Parser<T> e)
{
    return new Mapper<ExprNode>() {
        @SuppressWarnings("unused")
        public ExprNode map (T node)
        {
            ExprNode r = node;

            if (r == null) {
                r = new ConsNode.Tuple(Collections.<ExprNode>emptyList());
            } else if (!(r instanceof ConsNode.Tuple) && !(r instanceof PNode)) {
                r = new PNode(node);
            }

            return r;
        }
    }.sequence(any(e).optional().between(term("("), term(")")));
}
 
开发者ID:impl,项目名称:yashiro,代码行数:19,代码来源:ExpressionParser.java

示例12: argumentList

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
static <T extends ExprNode> Parser<InvArgListNode> argumentList (Parser<T> e)
{
    Parser<InvArgNode> namedArg = Mapper.<InvArgNode>curry(InvArgNode.Named.class).sequence(NAME_PARSER, term("="), e);
    Parser<InvArgNode> arg = namedArg.or(Mapper.curry(InvArgNode.Positional.class).sequence(e));

    Parser<InvArgNode> manyArgs = Mapper.<InvArgNode>curry(InvArgNode.ManyArgs.class).sequence(term("*"), e);
    Parser<InvArgNode> keywordArgs = Mapper.<InvArgNode>curry(InvArgNode.KeywordArgs.class).sequence(term("**"), e);

    /* Gleefully stolen from the Python grammar file. */
    Parser<List<InvArgNode>> parser;
    parser = Parsers2.collect(
            arg.sepEndBy(term(",")),
            Parsers.or(
                    Parsers2.collectN1(manyArgs, term(",").next(namedArg.sepBy1(term(","))).atomic().optional(), term(",").next(keywordArgs).optional()),
                    Parsers2.list(keywordArgs),
                    Parsers2.list(arg.followedBy(term(",")).optional())));
    parser = Parsers2.filter(parser, Predicates.<InvArgNode>notNull());

    return Mapper.curry(InvArgListNode.class).sequence(parser);
}
 
开发者ID:impl,项目名称:yashiro,代码行数:21,代码来源:ExpressionParser.java

示例13: data

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
Parser<DataNode> data ()
{
    return Marker.mark(Mapper.curry(DataNode.class).sequence(
            new Mapper<String>()
            {
                public String map(Stripping stripLeading, List<String> bodies, Stripping stripTrailing)
                {
                    String body = Joiner.on("").join(bodies);

                    if (stripLeading == Stripping.ALL)
                        body = CharMatcher.WHITESPACE.trimLeadingFrom(body);

                    if (stripTrailing == Stripping.ALL)
                        body = CharMatcher.WHITESPACE.trimTrailingFrom(body);
                    else if (stripTrailing == Stripping.LINE)
                        body = LINE_STRIP_PATTERN.matcher(body).replaceFirst("");

                    return body;
                }
            }.sequence(strip().optional(Stripping.NONE), Parsers.or(TagParsers.data(), Parsers.EOF.retn("")).many1(), strip().optional(Stripping.NONE))));
}
 
开发者ID:impl,项目名称:yashiro,代码行数:22,代码来源:BodyParser.java

示例14: parserOf

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
@SafeVarargs
public final <U extends T> Parser<?> parserOf (final U... expected)
{
    if (expected.length == 0) {
        return Parsers.never();
    } else if (expected.length == 1) {
        return parserOf(expected[0]);
    }

    Parser<?>[] parsers = new Parser<?>[expected.length];
    for (int i = 0; i < expected.length; i++)
    {
        parsers[i] = parserOf(expected[i]);
    }
    return Parsers.sequence(parsers);
}
 
开发者ID:impl,项目名称:yashiro,代码行数:17,代码来源:Tag.java

示例15: mapWith

import org.codehaus.jparsec.Parser; //导入依赖的package包/类
public <T extends StmtNode> StatementParser mapWith (final Map<ContentMatchMap, T> map)
{
    checkNotNull(map);

    return new StatementParser()
    {
        @Override
        public String getPackage()
        {
            return callables.getPackageName();
        }

        @Override
        public String getName ()
        {
            return callables.getName();
        }

        @Override
        public Parser<T> parser (Cont cont)
        {
            ContentParserBuilder content = contents.getContent();
            return cont.name().next(content.parser().map(map));
        }
    };
}
 
开发者ID:impl,项目名称:yashiro,代码行数:27,代码来源:StatementWithoutBodyParserBuilder.java


注:本文中的org.codehaus.jparsec.Parser类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。