Xsd2cc是一个霸气的C++代码生成器,直接从指定的XML数据格式定义文件(.xsd)生成对应的C++类代码,然后将这些代码和xsd2cc库结合(自带的),就可以非常方便的写XML数据解析了(未来准备自动生成)。Xsd2cc是基于C++的对象模型构建的,仅仅依赖libxml库,支持快速、高效的XML文档解析。Xsd2cc是由STL实现,无异常,无需手工内存管理,安全、可靠,简单易用。
根据作者大量调查分析,目前xsd2cc是此类场景下最好用的C++开源软件。如果你正在处理类似的场景,xsd2cc正是你需要的,千万不要错过。高效的自动化代码生成才是王道,才是应对变化的秘密武器。Xsd2cc在GPL下开源,欢迎使用和反馈。
Xsd2cc的主要产出物:
(1)xsd2cc: 可执行程序,用于从.xsd生成C++代码文件;
(2)libxsd2cc.a: 业务编写所需的静态库;
(3)xsd2cc.h: 业务编写需要的API文件(已include到自动生成的代码中)。
xsd2cc的主要特色:
(1)从指定的.xsd文件,生成高效的C++类代码,以解析xsd对应的各种XML数据;
(2)支持XML的序列化和反序列化操作。通俗的讲,就是XML的读和写;
(3)提供业务编写所需的静态库xsd2cc和自描述的API文件;
(4)构建于C++对象系统之上,仅依赖于C++ STL,无需手工内存管理,安全可靠;
(5)生成的代码遵从Google C++编码规范,表里如一;
(6)具备良好的跨平台移植能力(当然 Windows 除外):目前支持Linux, IBM AIX, HP-UX and Mac OS X。
(7)在GPL下开源。
具体的流程图,如下:(以 test.xsd 为例。红色内容为工具使用者需要供的部分。)
xsd2cc的缺点:
(1)仅针对C++应用。
xsd2cc的TODO:
(1)多文件处理支持:进一步优化xsd语法中 include和import的支持;
(2)自动化生成XML读写代码逻辑,减少用户编写代码的量;
(3)代码优化。
预知详情,请访问 http://xsd2cc.github.io 并参考 https://github.com/xsd2cc/xsd2cc/tree/master/tests 下的测试代码。
======== 更新 ===== 2015-04-18=======
(1)增加了部分Wiki文档,和简要的使用说明。(后续应该会写一个基于 gitbook 的使用手册)
根据XSD定义生成C++类 可以使用xsdcxx或xsde库 CodeSynthesis XSD/e is an open-source, dependency-free XML Schema to C++ compiler for mobile, embedded, and light-weight applications. It provides XML parsing, serializa
复杂类型是指定义元素中包含属性或者子元素的类型 1、只包含子元素的复杂类型 <xsd:element name="person">定义一个元素 <xsd:complexType>它的类型是复杂类型 <xsd:sequence>它包含以下两个简单类型的元素 <xsd:element name="firstname" type="xsd:string"/> <xsd:element name="las
看下面这段简单的xsd: <?xml version="1.0" encoding="UTF-8"?> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified" attributeFormDefault="unqualified"> <xs:element name="d
我正在根据参考指南学习使用Map结构。日食验证是 面向Web开发人员的Eclipse Java EE IDE。版本:开普勒服务版本2 pom。xml如下所示,与参考指南相同 它表示在构建项目时将生成实现代码。但是,它似乎不会在目标/生成的源文件夹下生成
Jboot 内置了一个简易的代码生成器,可以用来生成model层和Service层的基础代码,在生成代码之前,请先配置jboot.properties关于数据库相关的配置信息,Jboot 代码生成器会通过该配置去链接数据库。 jboot.datasource.type=mysql jboot.datasource.url=jdbc:mysql://127.0.0.1:3306/jbootdemo
遵照此规范,在实际操作中,有许多重复。接下来推荐一款专为本规范量身定做的代码生成器 Laravel 5.x Scaffold Generator。 本扩展支持 5.1 ~ 5.5 版本的 Laravel。 只需要一个命令: 即可生成: $ php artisan make:scaffold Projects --schema="name:string:index,description:text:
Sergen 有一些额外的配置选项,你可以通过解决方案目录下的配置文件(Serenity.CodeGenerator.config)设置。 这是所有的配置选项: public class GeneratorConfig { public List<Connection> Connections { get; set; } public string KDiff3Path { get
我使用jOOQ程序代码生成数据库,但现在我遇到了一些问题。在数据库中,我有表A和表B。第一次都生成了pojo、dao、接口等。经过一段时间的开发,我发现表A需要添加一些字段或修改一些字段,所以我不得不再次编码,然后jOOQ代码生成器将覆盖现有的代码,这让我很难过。当我在排除表的情况下使用“排除A”时,发现只生成了表A的数据,表B将被删除。我不知道如何处理这个问题。我的代码生成器如下:
根据数据库表生成对应的增,删,改,查功能,和 js 验证功能! 目前支持的是oracle 数据库,写自行修改 项目本身可以做为PHP新手的入门程序!
大多数Blockly应用程序需要将块转换为代码以执行。本页描述如何将代码生成器添加到自定义块。 首先,转到generators/目录并选择与您要生成的语言(JavaScript,Python,PHP,Lua,Dart等)相对应的子目录。假设您的代码块不适合现有类别,请创建一个新的JavaScript文件。这个新的JavaScript文件需要包含在<script ...>编辑器的HTML文件中的标记
注: 内容来自官网资料 Java Generated Code 这个页面准确描述 protocol buffer 编译器为任何给定协议定义生成的java代码。proto2和proto3生成的代码之间的任何不同都将被高亮 - 注意在这份文档中描述的是这些生成代码的不同,而不是基本的消息类/接口,后者在两个版本中是相同的。在阅读这份文档之前你应该先阅读 proto2语言指南 和/或 proto3语言指