原创分享 XSD 模式语言解析引擎与跨语言代码生成器

xuri · 2020年03月26日 · 38 次阅读

github.com/xuri/xgen

xgen 是 Go 语言编写的 XSD (XML Schema Definition) 工具基础库,其命令行工具的目标是将 XML 模式定义文件编译为包括 Go/C/Java/Rust/TypeScript 在内的多语言类型或类声明代码。

GitHub 开源:github.com/xuri/xgen

安装命令行工具:

xgen [<flag> ...] <XSD file or directory> ...
   -i <path> Input file path or directory for the XML schema definition
   -o <path> Output file path or directory for the generated code
   -p        Specify the package name
   -l        Specify the language of generated code (Go/C/Java/Rust/TypeScript)
   -h        Output this help and exit
   -v        Output version and exit

例如,下面的命令将遍历 xsd 目录中的 XML 模式定义文件,并在 output 目录中生成 Go 语言结构体声明代码:

xgen -i /path/to/your/xsd -o /path/to/your/output -l Go

XSD 源文件:

<schema xmlns="http://www.w3.org/2001/XMLSchema" targetNamespace="http://example.org/">
  <simpleType name="myType1">
    <restriction base="base64Binary">
      <length value="10" />
    </restriction>
  </simpleType>

  <complexType name="myType2">
    <simpleContent>
      <extension base="base64Binary">
        <attribute name="length" type="int"/>
      </extension>
    </simpleContent>
  </complexType>

  <complexType name="myType3">
    <simpleContent>
      <extension base="date">
        <attribute name="length" type="int"/>
      </extension>
    </simpleContent>
  </complexType>

  <complexType name="myType4">
    <sequence>
      <element name="title" type="string"/>
      <element name="blob" type="base64Binary"/>
      <element name="timestamp" type="dateTime"/>
    </sequence>
  </complexType>

  <simpleType name="myType5">
    <restriction base="gDay"/>
  </simpleType>
</schema>

生成 Go 语言代码:

// Copyright 2020 The xgen Authors. All rights reserved.
//
// DO NOT EDIT: generated by xgen XSD generator
//
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

package schema

import (
    "encoding/xml"
    "time"
)

// MyType1 ...
type MyType1 []byte

// MyType2 ...
type MyType2 struct {
    XMLName    xml.Name `xml:"myType2"`
    LengthAttr int      `xml:"length,attr,omitempty"`
}

// MyType3 ...
type MyType3 struct {
    XMLName    xml.Name `xml:"myType3"`
    LengthAttr int      `xml:"length,attr,omitempty"`
}

// MyType4 ...
type MyType4 struct {
    XMLName   xml.Name  `xml:"myType4"`
    Title     string    `xml:"title"`
    Blob      []byte    `xml:"blob"`
    Timestamp time.Time `xml:"timestamp"`
}

// MyType5 ...
type MyType5 time.Time
更多原创文章干货分享,请关注公众号
  • 加微信实战群请加微信(注明:实战群):gocnio
暂无回复。
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册