260 lines
6.5 KiB
Go
Raw Normal View History

2017-08-28 20:56:18 -05:00
// Copyright 2017 Baliance. All rights reserved.
//
// 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 chart
import (
"encoding/xml"
"fmt"
"log"
"baliance.com/gooxml/schema/schemas.openxmlformats.org/drawingml"
)
type CT_LineSer struct {
Idx *CT_UnsignedInt
Order *CT_UnsignedInt
Tx *CT_SerTx
SpPr *drawingml.CT_ShapeProperties
Marker *CT_Marker
DPt []*CT_DPt
DLbls *CT_DLbls
Trendline []*CT_Trendline
ErrBars *CT_ErrBars
Cat *CT_AxDataSource
Val *CT_NumDataSource
Smooth *CT_Boolean
ExtLst *CT_ExtensionList
}
func NewCT_LineSer() *CT_LineSer {
ret := &CT_LineSer{}
ret.Idx = NewCT_UnsignedInt()
ret.Order = NewCT_UnsignedInt()
return ret
}
2017-08-28 20:56:18 -05:00
func (m *CT_LineSer) MarshalXML(e *xml.Encoder, start xml.StartElement) error {
if m == nil {
return nil
}
e.EncodeToken(start)
seidx := xml.StartElement{Name: xml.Name{Local: "idx"}}
e.EncodeElement(m.Idx, seidx)
seorder := xml.StartElement{Name: xml.Name{Local: "order"}}
e.EncodeElement(m.Order, seorder)
if m.Tx != nil {
setx := xml.StartElement{Name: xml.Name{Local: "tx"}}
e.EncodeElement(m.Tx, setx)
}
if m.SpPr != nil {
sespPr := xml.StartElement{Name: xml.Name{Local: "spPr"}}
e.EncodeElement(m.SpPr, sespPr)
}
if m.Marker != nil {
semarker := xml.StartElement{Name: xml.Name{Local: "marker"}}
e.EncodeElement(m.Marker, semarker)
}
if m.DPt != nil {
sedPt := xml.StartElement{Name: xml.Name{Local: "dPt"}}
e.EncodeElement(m.DPt, sedPt)
}
if m.DLbls != nil {
sedLbls := xml.StartElement{Name: xml.Name{Local: "dLbls"}}
e.EncodeElement(m.DLbls, sedLbls)
}
if m.Trendline != nil {
setrendline := xml.StartElement{Name: xml.Name{Local: "trendline"}}
e.EncodeElement(m.Trendline, setrendline)
}
if m.ErrBars != nil {
seerrBars := xml.StartElement{Name: xml.Name{Local: "errBars"}}
e.EncodeElement(m.ErrBars, seerrBars)
}
if m.Cat != nil {
secat := xml.StartElement{Name: xml.Name{Local: "cat"}}
e.EncodeElement(m.Cat, secat)
}
if m.Val != nil {
seval := xml.StartElement{Name: xml.Name{Local: "val"}}
e.EncodeElement(m.Val, seval)
}
if m.Smooth != nil {
sesmooth := xml.StartElement{Name: xml.Name{Local: "smooth"}}
e.EncodeElement(m.Smooth, sesmooth)
}
if m.ExtLst != nil {
seextLst := xml.StartElement{Name: xml.Name{Local: "extLst"}}
e.EncodeElement(m.ExtLst, seextLst)
}
e.EncodeToken(xml.EndElement{Name: start.Name})
return nil
}
2017-08-28 20:56:18 -05:00
func (m *CT_LineSer) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error {
// initialize to default
m.Idx = NewCT_UnsignedInt()
m.Order = NewCT_UnsignedInt()
lCT_LineSer:
for {
tok, err := d.Token()
if err != nil {
return err
}
switch el := tok.(type) {
case xml.StartElement:
switch el.Name.Local {
case "idx":
if err := d.DecodeElement(m.Idx, &el); err != nil {
return err
}
case "order":
if err := d.DecodeElement(m.Order, &el); err != nil {
return err
}
case "tx":
m.Tx = NewCT_SerTx()
if err := d.DecodeElement(m.Tx, &el); err != nil {
return err
}
case "spPr":
m.SpPr = drawingml.NewCT_ShapeProperties()
if err := d.DecodeElement(m.SpPr, &el); err != nil {
return err
}
case "marker":
m.Marker = NewCT_Marker()
if err := d.DecodeElement(m.Marker, &el); err != nil {
return err
}
case "dPt":
tmp := NewCT_DPt()
if err := d.DecodeElement(tmp, &el); err != nil {
return err
}
m.DPt = append(m.DPt, tmp)
case "dLbls":
m.DLbls = NewCT_DLbls()
if err := d.DecodeElement(m.DLbls, &el); err != nil {
return err
}
case "trendline":
tmp := NewCT_Trendline()
if err := d.DecodeElement(tmp, &el); err != nil {
return err
}
m.Trendline = append(m.Trendline, tmp)
case "errBars":
m.ErrBars = NewCT_ErrBars()
if err := d.DecodeElement(m.ErrBars, &el); err != nil {
return err
}
case "cat":
m.Cat = NewCT_AxDataSource()
if err := d.DecodeElement(m.Cat, &el); err != nil {
return err
}
case "val":
m.Val = NewCT_NumDataSource()
if err := d.DecodeElement(m.Val, &el); err != nil {
return err
}
case "smooth":
m.Smooth = NewCT_Boolean()
if err := d.DecodeElement(m.Smooth, &el); err != nil {
return err
}
case "extLst":
m.ExtLst = NewCT_ExtensionList()
if err := d.DecodeElement(m.ExtLst, &el); err != nil {
return err
}
default:
log.Printf("skipping unsupported element on CT_LineSer %v", el.Name)
2017-08-28 20:56:18 -05:00
if err := d.Skip(); err != nil {
return err
}
}
case xml.EndElement:
break lCT_LineSer
case xml.CharData:
}
}
return nil
}
// Validate validates the CT_LineSer and its children
2017-08-28 20:56:18 -05:00
func (m *CT_LineSer) Validate() error {
return m.ValidateWithPath("CT_LineSer")
}
// ValidateWithPath validates the CT_LineSer and its children, prefixing error messages with path
2017-08-28 20:56:18 -05:00
func (m *CT_LineSer) ValidateWithPath(path string) error {
if err := m.Idx.ValidateWithPath(path + "/Idx"); err != nil {
return err
}
if err := m.Order.ValidateWithPath(path + "/Order"); err != nil {
return err
}
if m.Tx != nil {
if err := m.Tx.ValidateWithPath(path + "/Tx"); err != nil {
return err
}
}
if m.SpPr != nil {
if err := m.SpPr.ValidateWithPath(path + "/SpPr"); err != nil {
return err
}
}
if m.Marker != nil {
if err := m.Marker.ValidateWithPath(path + "/Marker"); err != nil {
return err
}
}
for i, v := range m.DPt {
if err := v.ValidateWithPath(fmt.Sprintf("%s/DPt[%d]", path, i)); err != nil {
return err
}
}
if m.DLbls != nil {
if err := m.DLbls.ValidateWithPath(path + "/DLbls"); err != nil {
return err
}
}
for i, v := range m.Trendline {
if err := v.ValidateWithPath(fmt.Sprintf("%s/Trendline[%d]", path, i)); err != nil {
return err
}
}
if m.ErrBars != nil {
if err := m.ErrBars.ValidateWithPath(path + "/ErrBars"); err != nil {
return err
}
}
if m.Cat != nil {
if err := m.Cat.ValidateWithPath(path + "/Cat"); err != nil {
return err
}
}
if m.Val != nil {
if err := m.Val.ValidateWithPath(path + "/Val"); err != nil {
return err
}
}
if m.Smooth != nil {
if err := m.Smooth.ValidateWithPath(path + "/Smooth"); err != nil {
return err
}
}
if m.ExtLst != nil {
if err := m.ExtLst.ValidateWithPath(path + "/ExtLst"); err != nil {
return err
}
}
return nil
}