mirror of
https://github.com/unidoc/unioffice.git
synced 2025-04-29 13:49:10 +08:00

One of the pml types has two attributes named 'id' with one being a reference. This allows that to be unmarshaled correctly.
261 lines
7.1 KiB
Go
261 lines
7.1 KiB
Go
// Copyright 2017 Baliance. All rights reserved.
|
|
//
|
|
// DO NOT EDIT: generated by gooxml ECMA-376 generator
|
|
//
|
|
// Use of this source code is governed by the terms of the Affero GNU General
|
|
// Public License version 3.0 as published by the Free Software Foundation and
|
|
// appearing in the file LICENSE included in the packaging of this file. A
|
|
// commercial license can be purchased by contacting sales@baliance.com.
|
|
|
|
package dml
|
|
|
|
import (
|
|
"encoding/xml"
|
|
"fmt"
|
|
"strconv"
|
|
|
|
"baliance.com/gooxml"
|
|
)
|
|
|
|
type CT_Path2D struct {
|
|
WAttr *int64
|
|
HAttr *int64
|
|
FillAttr ST_PathFillMode
|
|
StrokeAttr *bool
|
|
ExtrusionOkAttr *bool
|
|
Close []*CT_Path2DClose
|
|
MoveTo []*CT_Path2DMoveTo
|
|
LnTo []*CT_Path2DLineTo
|
|
ArcTo []*CT_Path2DArcTo
|
|
QuadBezTo []*CT_Path2DQuadBezierTo
|
|
CubicBezTo []*CT_Path2DCubicBezierTo
|
|
}
|
|
|
|
func NewCT_Path2D() *CT_Path2D {
|
|
ret := &CT_Path2D{}
|
|
return ret
|
|
}
|
|
|
|
func (m *CT_Path2D) MarshalXML(e *xml.Encoder, start xml.StartElement) error {
|
|
if m.WAttr != nil {
|
|
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "w"},
|
|
Value: fmt.Sprintf("%v", *m.WAttr)})
|
|
}
|
|
if m.HAttr != nil {
|
|
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "h"},
|
|
Value: fmt.Sprintf("%v", *m.HAttr)})
|
|
}
|
|
if m.FillAttr != ST_PathFillModeUnset {
|
|
attr, err := m.FillAttr.MarshalXMLAttr(xml.Name{Local: "fill"})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
start.Attr = append(start.Attr, attr)
|
|
}
|
|
if m.StrokeAttr != nil {
|
|
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "stroke"},
|
|
Value: fmt.Sprintf("%d", b2i(*m.StrokeAttr))})
|
|
}
|
|
if m.ExtrusionOkAttr != nil {
|
|
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "extrusionOk"},
|
|
Value: fmt.Sprintf("%d", b2i(*m.ExtrusionOkAttr))})
|
|
}
|
|
e.EncodeToken(start)
|
|
if m.Close != nil {
|
|
seclose := xml.StartElement{Name: xml.Name{Local: "a:close"}}
|
|
for _, c := range m.Close {
|
|
e.EncodeElement(c, seclose)
|
|
}
|
|
}
|
|
if m.MoveTo != nil {
|
|
semoveTo := xml.StartElement{Name: xml.Name{Local: "a:moveTo"}}
|
|
for _, c := range m.MoveTo {
|
|
e.EncodeElement(c, semoveTo)
|
|
}
|
|
}
|
|
if m.LnTo != nil {
|
|
selnTo := xml.StartElement{Name: xml.Name{Local: "a:lnTo"}}
|
|
for _, c := range m.LnTo {
|
|
e.EncodeElement(c, selnTo)
|
|
}
|
|
}
|
|
if m.ArcTo != nil {
|
|
searcTo := xml.StartElement{Name: xml.Name{Local: "a:arcTo"}}
|
|
for _, c := range m.ArcTo {
|
|
e.EncodeElement(c, searcTo)
|
|
}
|
|
}
|
|
if m.QuadBezTo != nil {
|
|
sequadBezTo := xml.StartElement{Name: xml.Name{Local: "a:quadBezTo"}}
|
|
for _, c := range m.QuadBezTo {
|
|
e.EncodeElement(c, sequadBezTo)
|
|
}
|
|
}
|
|
if m.CubicBezTo != nil {
|
|
secubicBezTo := xml.StartElement{Name: xml.Name{Local: "a:cubicBezTo"}}
|
|
for _, c := range m.CubicBezTo {
|
|
e.EncodeElement(c, secubicBezTo)
|
|
}
|
|
}
|
|
e.EncodeToken(xml.EndElement{Name: start.Name})
|
|
return nil
|
|
}
|
|
|
|
func (m *CT_Path2D) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error {
|
|
// initialize to default
|
|
for _, attr := range start.Attr {
|
|
if attr.Name.Local == "w" {
|
|
parsed, err := strconv.ParseInt(attr.Value, 10, 64)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
m.WAttr = &parsed
|
|
continue
|
|
}
|
|
if attr.Name.Local == "h" {
|
|
parsed, err := strconv.ParseInt(attr.Value, 10, 64)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
m.HAttr = &parsed
|
|
continue
|
|
}
|
|
if attr.Name.Local == "fill" {
|
|
m.FillAttr.UnmarshalXMLAttr(attr)
|
|
continue
|
|
}
|
|
if attr.Name.Local == "stroke" {
|
|
parsed, err := strconv.ParseBool(attr.Value)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
m.StrokeAttr = &parsed
|
|
continue
|
|
}
|
|
if attr.Name.Local == "extrusionOk" {
|
|
parsed, err := strconv.ParseBool(attr.Value)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
m.ExtrusionOkAttr = &parsed
|
|
continue
|
|
}
|
|
}
|
|
lCT_Path2D:
|
|
for {
|
|
tok, err := d.Token()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
switch el := tok.(type) {
|
|
case xml.StartElement:
|
|
switch el.Name {
|
|
case xml.Name{Space: "http://schemas.openxmlformats.org/drawingml/2006/main", Local: "close"}:
|
|
tmp := NewCT_Path2DClose()
|
|
if err := d.DecodeElement(tmp, &el); err != nil {
|
|
return err
|
|
}
|
|
m.Close = append(m.Close, tmp)
|
|
case xml.Name{Space: "http://schemas.openxmlformats.org/drawingml/2006/main", Local: "moveTo"}:
|
|
tmp := NewCT_Path2DMoveTo()
|
|
if err := d.DecodeElement(tmp, &el); err != nil {
|
|
return err
|
|
}
|
|
m.MoveTo = append(m.MoveTo, tmp)
|
|
case xml.Name{Space: "http://schemas.openxmlformats.org/drawingml/2006/main", Local: "lnTo"}:
|
|
tmp := NewCT_Path2DLineTo()
|
|
if err := d.DecodeElement(tmp, &el); err != nil {
|
|
return err
|
|
}
|
|
m.LnTo = append(m.LnTo, tmp)
|
|
case xml.Name{Space: "http://schemas.openxmlformats.org/drawingml/2006/main", Local: "arcTo"}:
|
|
tmp := NewCT_Path2DArcTo()
|
|
if err := d.DecodeElement(tmp, &el); err != nil {
|
|
return err
|
|
}
|
|
m.ArcTo = append(m.ArcTo, tmp)
|
|
case xml.Name{Space: "http://schemas.openxmlformats.org/drawingml/2006/main", Local: "quadBezTo"}:
|
|
tmp := NewCT_Path2DQuadBezierTo()
|
|
if err := d.DecodeElement(tmp, &el); err != nil {
|
|
return err
|
|
}
|
|
m.QuadBezTo = append(m.QuadBezTo, tmp)
|
|
case xml.Name{Space: "http://schemas.openxmlformats.org/drawingml/2006/main", Local: "cubicBezTo"}:
|
|
tmp := NewCT_Path2DCubicBezierTo()
|
|
if err := d.DecodeElement(tmp, &el); err != nil {
|
|
return err
|
|
}
|
|
m.CubicBezTo = append(m.CubicBezTo, tmp)
|
|
default:
|
|
gooxml.Log("skipping unsupported element on CT_Path2D %v", el.Name)
|
|
if err := d.Skip(); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
case xml.EndElement:
|
|
break lCT_Path2D
|
|
case xml.CharData:
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Validate validates the CT_Path2D and its children
|
|
func (m *CT_Path2D) Validate() error {
|
|
return m.ValidateWithPath("CT_Path2D")
|
|
}
|
|
|
|
// ValidateWithPath validates the CT_Path2D and its children, prefixing error messages with path
|
|
func (m *CT_Path2D) ValidateWithPath(path string) error {
|
|
if m.WAttr != nil {
|
|
if *m.WAttr < 0 {
|
|
return fmt.Errorf("%s/m.WAttr must be >= 0 (have %v)", path, *m.WAttr)
|
|
}
|
|
if *m.WAttr > 27273042316900 {
|
|
return fmt.Errorf("%s/m.WAttr must be <= 27273042316900 (have %v)", path, *m.WAttr)
|
|
}
|
|
}
|
|
if m.HAttr != nil {
|
|
if *m.HAttr < 0 {
|
|
return fmt.Errorf("%s/m.HAttr must be >= 0 (have %v)", path, *m.HAttr)
|
|
}
|
|
if *m.HAttr > 27273042316900 {
|
|
return fmt.Errorf("%s/m.HAttr must be <= 27273042316900 (have %v)", path, *m.HAttr)
|
|
}
|
|
}
|
|
if err := m.FillAttr.ValidateWithPath(path + "/FillAttr"); err != nil {
|
|
return err
|
|
}
|
|
for i, v := range m.Close {
|
|
if err := v.ValidateWithPath(fmt.Sprintf("%s/Close[%d]", path, i)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
for i, v := range m.MoveTo {
|
|
if err := v.ValidateWithPath(fmt.Sprintf("%s/MoveTo[%d]", path, i)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
for i, v := range m.LnTo {
|
|
if err := v.ValidateWithPath(fmt.Sprintf("%s/LnTo[%d]", path, i)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
for i, v := range m.ArcTo {
|
|
if err := v.ValidateWithPath(fmt.Sprintf("%s/ArcTo[%d]", path, i)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
for i, v := range m.QuadBezTo {
|
|
if err := v.ValidateWithPath(fmt.Sprintf("%s/QuadBezTo[%d]", path, i)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
for i, v := range m.CubicBezTo {
|
|
if err := v.ValidateWithPath(fmt.Sprintf("%s/CubicBezTo[%d]", path, i)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|