当前位置: 首页 > news >正文

接给别人做网站的活市环保局网站建设方案

接给别人做网站的活,市环保局网站建设方案,建筑工程网课哪个好,调颜色网站antlr4 代码 语法树DSL是很酷的东西#xff0c;但我不清楚它们有什么用。 然后我意识到它们对以下方面有好处#xff1a; 摆脱复杂的UI 意思是 更快的做事方式 而已。 当我阅读此博客时#xff0c;我得出了这个结论。 如果您的用户是技术人员#xff0c;并且不惧怕类… antlr4 代码 语法树 DSL是很酷的东西但我不清楚它们有什么用。 然后我意识到它们对以下方面有好处 摆脱复杂的UI 意思是 更快的做事方式 而已。 当我阅读此博客时我得出了这个结论。 如果您的用户是技术人员并且不惧怕类似SQL的语法处理方式则DSL特别适合 你有语法高亮 你有代码补全 否则DSL有点烂。 因此我不得不向客户提出一些概念证明。 他有模糊的要求要准确提取团队的需求并不容易他们需要很多东西而且他很忙因此DSL可以在此过程中提供很多帮助因为人们被迫在他们需要时才想清楚他们的需求面对一种语法甚至很小的一种。 因此我采用了以下技术 用于代码镜像的JSF库Primefaces扩展 ANTLR4 与ANTLR3相比有很大的改进而且本书很棒 不幸的是我无法在两个工具中重复使用语法。 实际上我找不到任何可以做到这一点的解决方案。 至少对于基于Web的JSF解决方案。 而且没有时间学习。 所以我不得不稍微改一下。 首先我们需要语法。 ANTLR4比ANTLR3更好因为现在接线代码是通过访问者和侦听器完成的。 语法内没有更多的Java代码。 那很棒而且更容易使用。 所以你可以有一个这样的语法 grammar Grammar; options {language Java; } lexer::header {package parsers; }parser::header {package parsers; } eval : expr EOF; expr : JOB (jobName)? type TARGET targetList (START startExpr)? startExpr : AT cronTerm| AFTER timeAmount timeUnits; timeAmount: INT; jobName: STRING; targetList: STRING (, STRING)*; type : deleteUser| createUser;deleteUser: opDelete userName; createUser: opCreate userName; opDelete: DELETE; opCreate: CREATE; userName: STRING;cronTerm: !? (INT | - | / | * | | );timeUnits: MINUTES| HOURS| DAYS| WEEKS| MONTHS;WS : [ \t\r\n] - skip;STRING: ( ESC_SEQ | ~(\\|) )* ;fragment HEX_DIGIT : (0..9|a..f|A..F) ;fragment ESC_SEQ: \\ (b|t|n|f|r|\|\|\\)| UNICODE_ESC| OCTAL_ESC;fragment OCTAL_ESC: \\ (0..3) (0..7) (0..7)| \\ (0..7) (0..7)| \\ (0..7);fragment UNICODE_ESC: \\ u HEX_DIGIT HEX_DIGIT HEX_DIGIT HEX_DIGIT;ID : (a..z|A..Z|_) (a..z|A..Z|0..9|_)*;INT : 0..9; 要编译语法请尝试 public static void main(String[] args) {String[] arg0 {-visitor,/pathto/Grammar.g4};org.antlr.v4.Tool.main(arg0);} 然后ANTLR将为您生成类。 在我们的例子中我们想访问解析树并检索我们想要的值。 我们这样做扩展了生成的抽象类。 import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.StringTokenizer;import org.antlr.v4.runtime.tree.ErrorNode;import bsh.EvalError; import bsh.Interpreter;public class MyLoader2 extends GrammarBaseVisitorVoid {private String jobName,cronTerm,timeUnits,userName,jobType;private ListString targetList;private boolean now,errorFound;private int timeAmount; private Interpreter bsh new Interpreter();private String eval(String s) throws EvaluationException{try {if (!s.startsWith(\)){return s;}bsh.eval(String ss);return (String)bsh.eval(s);} catch (EvalError e) {throw new EvaluationException(s);}}Overridepublic Void visitTimeAmount(TimeAmountContext ctx) {try{this.timeAmount Integer.parseInt(ctx.getText());}catch(java.lang.NumberFormatException nfe){throw new InvalidTimeAmountException(ctx.getText());}return super.visitTimeAmount(ctx);}Overridepublic Void visitUserName(UserNameContext ctx) {this.userName eval(ctx.getText());return super.visitUserName(ctx);}Overridepublic Void visitCronTerm(CronTermContext ctx) {this.cronTerm eval(ctx.getText());return super.visitCronTerm(ctx);}Overridepublic Void visitTimeUnits(TimeUnitsContext ctx) {this.timeUnits ctx.getText();return super.visitTimeUnits(ctx);}Overridepublic Void visitTargetList(TargetListContext ctx) {this.targetList toStringList(ctx.getText());return super.visitTargetList(ctx);}Overridepublic Void visitJobName(JobNameContext ctx) {this.jobName eval(ctx.getText());return super.visitJobName(ctx);}Overridepublic Void visitOpCreate(OpCreateContext ctx) {this.jobType ctx.getText();return super.visitOpCreate(ctx);}Overridepublic Void visitOpDelete(OpDeleteContext ctx) {this.jobType ctx.getText();return super.visitOpDelete(ctx);}private ListString toStringList(String text) {ListString l new ArrayListString();StringTokenizer st new StringTokenizer(text, ,);while(st.hasMoreElements()){l.add(eval(st.nextToken()));}return l;}private MapString, String toMapList(String text) throws InvalidItemsException, InvalidKeyvalException {MapString, String m new HashMapString, String();if (text null || text.trim().length() 0){return m;}String[] items text.split(,);if (items.length 0){throw new InvalidItemsException();}for(String item:items){String[] keyval item.split();if (keyval.length 2){m.put(keyval[0], keyval[1]);}else{throw new InvalidKeyvalException(keyval.length);}}return m;}public String getJobName() {return jobName;}public String getCronTerm() {return cronTerm;}public String getTimeUnits() {return timeUnits;}public String getUserName() {return userName;}public String getJobType() {return jobType;}public ListString getTargetList() {return targetList;}public boolean isNow() {return now;}public int getTimeAmount() {return timeAmount;}Overridepublic Void visitOpNow(OpNowContext ctx) {this.now ctx.getText().equals(NOW);return super.visitOpNow(ctx);}public boolean isErrorFound() {return errorFound;}Overridepublic Void visitErrorNode(ErrorNode node) {this.errorFound true;return super.visitErrorNode(node);} } 请注意 beanshell解释器用于将“ xyz”之类的字符串评估为xyz。 这对于其中包含转义引号和字符的字符串特别有用。 因此您有了语法和visiter / loader bean然后我们可以对其进行测试 private static MyLoader getLoader(String str){ANTLRInputStream input new ANTLRInputStream(str);GrammarLexer lexer new GrammarLexer(input);CommonTokenStream tokens new CommonTokenStream(lexer);GrammarParser parser new GrammarParser(tokens);ParseTree tree parser.eval();MyLoader loader new MyLoader();loader.visit(tree);return loader; }public static void main(String[] args){MyLoader loader getLoader(JOB \jobName\ CREATE \myuser\ TARGET \site1\,\site2\ START AFTER 1 DAY);System.out.println(loader.getJobName());System.out.println(loader.getJobType()); } 大。 现在是黑客。 Code Mirror支持自定义语法但JSF Primefaces扩展中不存在 。 因此我打开了resources-codemirror-1.2.0.jar打开了/META-INF/resources/primefaces-extensions/codemirror/mode/modes.js文件对其进行了格式化 以便我可以阅读然后我刚刚选择了最简单的语言作为我的新自定义sintax荧光笔 我改名了 (...) }, xml), CodeMirror.defineMIME(text/x-markdown, markdown), CodeMirror.defineMode(mylanguage, function (e) { (...)var t e.indentUnit,n, i r([site, type, targetList]),s r([AT,AFTER,CREATE,MINUTES,HOURS,TARGET,MONTHS,JOB,DAYS,DELETE,START,WEEKS ]), (...) }), CodeMirror.defineMIME(text/x-mylanguage, mylanguage), CodeMirror.defineMode(ntriples, function () {(...) 那些在“ s r”中用大写字母表示的标记是将被突出显示的标记而在“ i r”中的那些标记则是将被突出显示的标记。 为什么我们都想要 因为第二种类型是“占位符”我的意思是我们将它们用于自动填充内容。 好那么您的JSF xhtml页面将如下所示 ?xml version1.0 encodingUTF-8 ? !DOCTYPE html PUBLIC -//W3C//DTD XHTML 1.0 Transitional//EN http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd html xmlnshttp://www.w3.org/1999/xhtmlxmlns:fhttp://java.sun.com/jsf/corexmlns:hhttp://java.sun.com/jsf/htmlxmlns:uihttp://java.sun.com/jsf/faceletsxmlns:phttp://primefaces.org/uixmlns:pehttp://primefaces.org/ui/extensionsh:body h:form idform pe:codeMirroridcodeMirrorstylewidth:600px; modemyLanguage widgetVarmyCodeMirror themeeclipsevalue#{myMB.script}lineNumberstrue completeMethod#{myMB.complete} extraKeys{ Ctrl-Space: function(cm) { PF(myCodeMirror).complete(); }}/ p:commandButton valueVerify action#{myMB.verify} / (...) 现在我们需要自动完成功能。 这是无聊的部分。 您必须手动完成大部分的完成工作因为没有上下文信息请记住我没有时间学习……所以快速而肮脏的方式是这样的 in myMBpublic ListString complete(final CompleteEvent event) {try {return this.myEJB.complete(event.getToken());} catch (Exception e) {jsfUtilEJB.addErrorMessage(e,Could not complete);return null;}} in myEJBprivate static final String SITE site_; public ListString complete(String token) throws Exception {if (token null || token.trim().length() 0){return null;}else{ListString suggestions new ArrayListString();switch(token){//first search variablescase targetlist:for(String v:TARGETS){suggestions.add(v); }break;case site:ListSite allSites this.baseService.getSiteDAO().getAll();for(Site s:allSites){suggestions.add(\SITEs.getName()\);}break;case type:suggestions.add(DELETE \userName\);suggestions.add(CREATE \userName\);break;case AT:suggestions.add(AT \cronExpression\);suggestions.add(AT \0 * * * * * * *\);break;case AFTER:for(int a:AMOUNTS){for(String u:UNITS){if (a 1){suggestions.add(AFTER a u);}else{suggestions.add(AFTER a uS);}}}break;case TARGET:for(String v:TARGETS){suggestions.add(TARGET v); }break;case JOB:suggestions.add(JOB \jobName\ \ntype \nTARGET targetlist \nSTART);break;case START:suggestions.add(START AT \cronExpression\);suggestions.add(START AT \0 * * * * * * *\);for(int a:AMOUNTS){for(String u:UNITS){if (a 1){suggestions.add(START AFTER a u);}else{suggestions.add(START AFTER a uS);}}}suggestions.add(START NOW);break;case DELETE:suggestions.add(DELETE \userName\);break;case CREATE:suggestions.add(CREATE \userName\);break;default:if (token.startsWith(SITE)){ListSite matchedSites this.baseService.getSiteDAO().getByPattern(token.substring(SITE.length())*);for(Site s:matchedSites){suggestions.add(\SITEs.getName()\);}}else{//then search substringsfor(String kw:KEYWORDS){if (kw.toLowerCase().startsWith(token.toLowerCase())){suggestions.add(kw);}}}}//end switch//remove dups and sortSetString ts new TreeSetString(suggestions); return new ArrayListString(ts);} }private static final int[] AMOUNTS {1,5,10}; private static final String[] UNITS {MINUTE,HOUR,DAY,WEEK,MONTH}; private static final String[] TARGETS {site};/** KEYWORDS are basic suggestions*/ private static final String[] KEYWORDS {AT,AFTER,CREATE,MINUTES,HOURS,TARGET,MONTHS,JOB,DAYS,DELETE,START,WEEKS}; 因此关键字的自动填充内容将仅向您显示字段和更多关键字而“占位符”还记得jar中的codemirror javascript中的小写关键字吗是从数据库中检索到的动态值用于实际值完成的。 另外您可以使用部分字符串来检索以子字符串开头的那些字符串如下所示 当然在JPA中类似模式的搜索可以这样执行 public abstract class GenericDAOE {protected EntityManager entityManager;private ClassE clazz;private EntityTypeE pClass;SuppressWarnings(unchecked)public GenericDAO(EntityManager entityManager) {this.entityManager entityManager;ParameterizedType genericSuperclass (ParameterizedType) getClass().getGenericSuperclass();this.clazz (ClassE) genericSuperclass.getActualTypeArguments()[0];EntityManagerFactory emf this.entityManager.getEntityManagerFactory();Metamodel metamodel emf.getMetamodel();this.pClass metamodel.entity(clazz);}public ListE getByPattern(String pattern) {pattern pattern.replace(?, _).replace(*, %);CriteriaBuilder cb entityManager.getCriteriaBuilder();CriteriaQueryE q cb.createQuery(clazz);RootE entity q.from(clazz);SingularAttributeE, String singularAttribute (SingularAttributeE, String) pClass.getDeclaredSingularAttribute(getNameableField(clazz));PathString path entity.get(singularAttribute);q.where(cb.like(path, pattern));q.select(entity);TypedQueryE tq entityManager.createQuery(q);ListE all tq.getResultList();return all;}private String getNameableField(ClassE clazz) {for(Field f : clazz.getDeclaredFields()) {for(Annotation a : f.getAnnotations()) {if(a.annotationType() Nameable.class) {return f.getName();}}}return null;} (...) 其中Nameable是您的实体类的注释 Retention(RetentionPolicy.RUNTIME) Target({ElementType.FIELD}) public interface Nameable { } 用它来注释实体类中的单个列即String。 像这样 Entity Table(uniqueConstraintsUniqueConstraint(columnNames{name})) public class Site implements Serializable {/****/private static final long serialVersionUID 8008732613898597654L;IdGeneratedValue(strategy GenerationType.AUTO)private Long id;NameableColumn(nullablefalse)private String name; (...) 当然“验证”按钮只是获取您的脚本并将其推入加载器。 参考来自Leos Notepad博客的JCG合作伙伴 Leonardo Shikida 使用ANTLR4用于代码镜像的Primefaces扩展和基于Web的DSL玩。 翻译自: https://www.javacodegeeks.com/2014/01/playing-with-antlr4-primefaces-extensions-for-code-mirror-and-web-based-dsls.htmlantlr4 代码 语法树
http://www.zqtcl.cn/news/331561/

相关文章:

  • wordpress站点费用vs手表官网
  • 网站买卖需要注意什么景安怎么把网站做别名
  • 网站建设网站建怎么做一个门户网站
  • 站长工具域名备案查询安卓app开发教程视频免费
  • 赶集网网站建设分析河南郑州旅游网站设计
  • 怎么可以黑网站域名建设网站的网站是什么
  • 帝国网站数据库配置文件建筑人才网招聘网官网首页
  • c 做的网站怎么上传图片阿里巴巴网站建设的目的
  • 保定模板建站平台微网站怎么做的好
  • 肇庆网站建设方案维护做学校网站素材图片素材
  • 新潮远网站建设建什么类型个人网站
  • 泉州中小企业网站制作洛浦县网站建设
  • 做游戏视频网站用什么程序好wordpress 地址修改
  • 大连的网站建设阳西网站seo
  • 网站制作电话多少网站商品图片怎么做
  • 定制做网站平台网站什么情况要更新
  • 上海网站建设哪家国外有哪些网站可以做电商
  • 网络软文推广网站wordpress仿站抓取软件
  • 安徽圣力建设集团网站当当网站建设与易趣网站对比
  • 长沙网站设计制作DW做注册网站
  • 商城设计网站关键词的优化在哪做
  • 网站锚文本网络营销的解释
  • 苏州专业网站建设网站模板是什么
  • 科技网站设计案例百度收录情况查询
  • gif放网站有锯齿策划公司宣传语
  • 淘宝客做网站怎样推广空间购买后打不开网站
  • 信阳网站设计银川网站建设nx110
  • 建设安全协会网站58招聘运营网站怎么做
  • 做原创的网站做游戏平面设计好的素材网站有哪些
  • 校园网站wordpress 防攻击插件