unioffice/schema/soo/dml/CT_ShapeLocking.go
Todd 629cfb008c schema: for xml ref attributes, check the namespace
One of the pml types has two attributes named 'id' with
one being a reference.  This allows that to be unmarshaled
correctly.
2017-11-18 11:52:13 -06:00

228 lines
6.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_ShapeLocking struct {
NoTextEditAttr *bool
ExtLst *CT_OfficeArtExtensionList
NoGrpAttr *bool
NoSelectAttr *bool
NoRotAttr *bool
NoChangeAspectAttr *bool
NoMoveAttr *bool
NoResizeAttr *bool
NoEditPointsAttr *bool
NoAdjustHandlesAttr *bool
NoChangeArrowheadsAttr *bool
NoChangeShapeTypeAttr *bool
}
func NewCT_ShapeLocking() *CT_ShapeLocking {
ret := &CT_ShapeLocking{}
return ret
}
func (m *CT_ShapeLocking) MarshalXML(e *xml.Encoder, start xml.StartElement) error {
if m.NoTextEditAttr != nil {
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "noTextEdit"},
Value: fmt.Sprintf("%d", b2i(*m.NoTextEditAttr))})
}
if m.NoGrpAttr != nil {
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "noGrp"},
Value: fmt.Sprintf("%d", b2i(*m.NoGrpAttr))})
}
if m.NoSelectAttr != nil {
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "noSelect"},
Value: fmt.Sprintf("%d", b2i(*m.NoSelectAttr))})
}
if m.NoRotAttr != nil {
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "noRot"},
Value: fmt.Sprintf("%d", b2i(*m.NoRotAttr))})
}
if m.NoChangeAspectAttr != nil {
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "noChangeAspect"},
Value: fmt.Sprintf("%d", b2i(*m.NoChangeAspectAttr))})
}
if m.NoMoveAttr != nil {
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "noMove"},
Value: fmt.Sprintf("%d", b2i(*m.NoMoveAttr))})
}
if m.NoResizeAttr != nil {
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "noResize"},
Value: fmt.Sprintf("%d", b2i(*m.NoResizeAttr))})
}
if m.NoEditPointsAttr != nil {
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "noEditPoints"},
Value: fmt.Sprintf("%d", b2i(*m.NoEditPointsAttr))})
}
if m.NoAdjustHandlesAttr != nil {
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "noAdjustHandles"},
Value: fmt.Sprintf("%d", b2i(*m.NoAdjustHandlesAttr))})
}
if m.NoChangeArrowheadsAttr != nil {
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "noChangeArrowheads"},
Value: fmt.Sprintf("%d", b2i(*m.NoChangeArrowheadsAttr))})
}
if m.NoChangeShapeTypeAttr != nil {
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "noChangeShapeType"},
Value: fmt.Sprintf("%d", b2i(*m.NoChangeShapeTypeAttr))})
}
e.EncodeToken(start)
if m.ExtLst != nil {
seextLst := xml.StartElement{Name: xml.Name{Local: "a:extLst"}}
e.EncodeElement(m.ExtLst, seextLst)
}
e.EncodeToken(xml.EndElement{Name: start.Name})
return nil
}
func (m *CT_ShapeLocking) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error {
// initialize to default
for _, attr := range start.Attr {
if attr.Name.Local == "noTextEdit" {
parsed, err := strconv.ParseBool(attr.Value)
if err != nil {
return err
}
m.NoTextEditAttr = &parsed
continue
}
if attr.Name.Local == "noGrp" {
parsed, err := strconv.ParseBool(attr.Value)
if err != nil {
return err
}
m.NoGrpAttr = &parsed
continue
}
if attr.Name.Local == "noSelect" {
parsed, err := strconv.ParseBool(attr.Value)
if err != nil {
return err
}
m.NoSelectAttr = &parsed
continue
}
if attr.Name.Local == "noRot" {
parsed, err := strconv.ParseBool(attr.Value)
if err != nil {
return err
}
m.NoRotAttr = &parsed
continue
}
if attr.Name.Local == "noChangeAspect" {
parsed, err := strconv.ParseBool(attr.Value)
if err != nil {
return err
}
m.NoChangeAspectAttr = &parsed
continue
}
if attr.Name.Local == "noMove" {
parsed, err := strconv.ParseBool(attr.Value)
if err != nil {
return err
}
m.NoMoveAttr = &parsed
continue
}
if attr.Name.Local == "noResize" {
parsed, err := strconv.ParseBool(attr.Value)
if err != nil {
return err
}
m.NoResizeAttr = &parsed
continue
}
if attr.Name.Local == "noEditPoints" {
parsed, err := strconv.ParseBool(attr.Value)
if err != nil {
return err
}
m.NoEditPointsAttr = &parsed
continue
}
if attr.Name.Local == "noAdjustHandles" {
parsed, err := strconv.ParseBool(attr.Value)
if err != nil {
return err
}
m.NoAdjustHandlesAttr = &parsed
continue
}
if attr.Name.Local == "noChangeArrowheads" {
parsed, err := strconv.ParseBool(attr.Value)
if err != nil {
return err
}
m.NoChangeArrowheadsAttr = &parsed
continue
}
if attr.Name.Local == "noChangeShapeType" {
parsed, err := strconv.ParseBool(attr.Value)
if err != nil {
return err
}
m.NoChangeShapeTypeAttr = &parsed
continue
}
}
lCT_ShapeLocking:
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: "extLst"}:
m.ExtLst = NewCT_OfficeArtExtensionList()
if err := d.DecodeElement(m.ExtLst, &el); err != nil {
return err
}
default:
gooxml.Log("skipping unsupported element on CT_ShapeLocking %v", el.Name)
if err := d.Skip(); err != nil {
return err
}
}
case xml.EndElement:
break lCT_ShapeLocking
case xml.CharData:
}
}
return nil
}
// Validate validates the CT_ShapeLocking and its children
func (m *CT_ShapeLocking) Validate() error {
return m.ValidateWithPath("CT_ShapeLocking")
}
// ValidateWithPath validates the CT_ShapeLocking and its children, prefixing error messages with path
func (m *CT_ShapeLocking) ValidateWithPath(path string) error {
if m.ExtLst != nil {
if err := m.ExtLst.ValidateWithPath(path + "/ExtLst"); err != nil {
return err
}
}
return nil
}