mirror of
https://github.com/unidoc/unioffice.git
synced 2025-04-29 13:49:10 +08:00
683 lines
20 KiB
Go
683 lines
20 KiB
Go
// 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 spreadsheetml
|
|
|
|
import (
|
|
"encoding/xml"
|
|
"fmt"
|
|
"log"
|
|
)
|
|
|
|
type CT_Worksheet struct {
|
|
// Worksheet Properties
|
|
SheetPr *CT_SheetPr
|
|
// Worksheet Dimensions
|
|
Dimension *CT_SheetDimension
|
|
// Sheet Views
|
|
SheetViews *CT_SheetViews
|
|
// Sheet Format Properties
|
|
SheetFormatPr *CT_SheetFormatPr
|
|
// Column Information
|
|
Cols []*CT_Cols
|
|
// Sheet Data
|
|
SheetData *CT_SheetData
|
|
// Sheet Calculation Properties
|
|
SheetCalcPr *CT_SheetCalcPr
|
|
// Sheet Protection
|
|
SheetProtection *CT_SheetProtection
|
|
// Protected Ranges
|
|
ProtectedRanges *CT_ProtectedRanges
|
|
// Scenarios
|
|
Scenarios *CT_Scenarios
|
|
// AutoFilter
|
|
AutoFilter *CT_AutoFilter
|
|
// Sort State
|
|
SortState *CT_SortState
|
|
// Data Consolidate
|
|
DataConsolidate *CT_DataConsolidate
|
|
// Custom Sheet Views
|
|
CustomSheetViews *CT_CustomSheetViews
|
|
// Merge Cells
|
|
MergeCells *CT_MergeCells
|
|
// Phonetic Properties
|
|
PhoneticPr *CT_PhoneticPr
|
|
// Conditional Formatting
|
|
ConditionalFormatting []*CT_ConditionalFormatting
|
|
// Data Validations
|
|
DataValidations *CT_DataValidations
|
|
// Hyperlinks
|
|
Hyperlinks *CT_Hyperlinks
|
|
// Print Options
|
|
PrintOptions *CT_PrintOptions
|
|
// Page Margins
|
|
PageMargins *CT_PageMargins
|
|
// Page Setup Settings
|
|
PageSetup *CT_PageSetup
|
|
// Header and Footer Settings
|
|
HeaderFooter *CT_HeaderFooter
|
|
// Horizontal Page Breaks
|
|
RowBreaks *CT_PageBreak
|
|
// Vertical Page Breaks
|
|
ColBreaks *CT_PageBreak
|
|
// Custom Properties
|
|
CustomProperties *CT_CustomProperties
|
|
// Cell Watch Items
|
|
CellWatches *CT_CellWatches
|
|
// Ignored Errors
|
|
IgnoredErrors *CT_IgnoredErrors
|
|
// Smart Tags
|
|
SmartTags *CT_SmartTags
|
|
// Drawing
|
|
Drawing *CT_Drawing
|
|
// Legacy Drawing
|
|
LegacyDrawing *CT_LegacyDrawing
|
|
// Legacy Drawing Header Footer
|
|
LegacyDrawingHF *CT_LegacyDrawing
|
|
DrawingHF *CT_DrawingHF
|
|
// Background Image
|
|
Picture *CT_SheetBackgroundPicture
|
|
OleObjects *CT_OleObjects
|
|
// Embedded Controls
|
|
Controls *CT_Controls
|
|
// Web Publishing Items
|
|
WebPublishItems *CT_WebPublishItems
|
|
// Table Parts
|
|
TableParts *CT_TableParts
|
|
// Future Feature Data Storage Area
|
|
ExtLst *CT_ExtensionList
|
|
}
|
|
|
|
func NewCT_Worksheet() *CT_Worksheet {
|
|
ret := &CT_Worksheet{}
|
|
ret.SheetData = NewCT_SheetData()
|
|
return ret
|
|
}
|
|
func (m *CT_Worksheet) MarshalXML(e *xml.Encoder, start xml.StartElement) error {
|
|
if m == nil {
|
|
return nil
|
|
}
|
|
e.EncodeToken(start)
|
|
start.Attr = nil
|
|
if m.SheetPr != nil {
|
|
sesheetPr := xml.StartElement{Name: xml.Name{Local: "x:sheetPr"}}
|
|
e.EncodeElement(m.SheetPr, sesheetPr)
|
|
}
|
|
if m.Dimension != nil {
|
|
sedimension := xml.StartElement{Name: xml.Name{Local: "x:dimension"}}
|
|
e.EncodeElement(m.Dimension, sedimension)
|
|
}
|
|
if m.SheetViews != nil {
|
|
sesheetViews := xml.StartElement{Name: xml.Name{Local: "x:sheetViews"}}
|
|
e.EncodeElement(m.SheetViews, sesheetViews)
|
|
}
|
|
if m.SheetFormatPr != nil {
|
|
sesheetFormatPr := xml.StartElement{Name: xml.Name{Local: "x:sheetFormatPr"}}
|
|
e.EncodeElement(m.SheetFormatPr, sesheetFormatPr)
|
|
}
|
|
if m.Cols != nil {
|
|
secols := xml.StartElement{Name: xml.Name{Local: "x:cols"}}
|
|
e.EncodeElement(m.Cols, secols)
|
|
}
|
|
sesheetData := xml.StartElement{Name: xml.Name{Local: "x:sheetData"}}
|
|
e.EncodeElement(m.SheetData, sesheetData)
|
|
if m.SheetCalcPr != nil {
|
|
sesheetCalcPr := xml.StartElement{Name: xml.Name{Local: "x:sheetCalcPr"}}
|
|
e.EncodeElement(m.SheetCalcPr, sesheetCalcPr)
|
|
}
|
|
if m.SheetProtection != nil {
|
|
sesheetProtection := xml.StartElement{Name: xml.Name{Local: "x:sheetProtection"}}
|
|
e.EncodeElement(m.SheetProtection, sesheetProtection)
|
|
}
|
|
if m.ProtectedRanges != nil {
|
|
seprotectedRanges := xml.StartElement{Name: xml.Name{Local: "x:protectedRanges"}}
|
|
e.EncodeElement(m.ProtectedRanges, seprotectedRanges)
|
|
}
|
|
if m.Scenarios != nil {
|
|
sescenarios := xml.StartElement{Name: xml.Name{Local: "x:scenarios"}}
|
|
e.EncodeElement(m.Scenarios, sescenarios)
|
|
}
|
|
if m.AutoFilter != nil {
|
|
seautoFilter := xml.StartElement{Name: xml.Name{Local: "x:autoFilter"}}
|
|
e.EncodeElement(m.AutoFilter, seautoFilter)
|
|
}
|
|
if m.SortState != nil {
|
|
sesortState := xml.StartElement{Name: xml.Name{Local: "x:sortState"}}
|
|
e.EncodeElement(m.SortState, sesortState)
|
|
}
|
|
if m.DataConsolidate != nil {
|
|
sedataConsolidate := xml.StartElement{Name: xml.Name{Local: "x:dataConsolidate"}}
|
|
e.EncodeElement(m.DataConsolidate, sedataConsolidate)
|
|
}
|
|
if m.CustomSheetViews != nil {
|
|
secustomSheetViews := xml.StartElement{Name: xml.Name{Local: "x:customSheetViews"}}
|
|
e.EncodeElement(m.CustomSheetViews, secustomSheetViews)
|
|
}
|
|
if m.MergeCells != nil {
|
|
semergeCells := xml.StartElement{Name: xml.Name{Local: "x:mergeCells"}}
|
|
e.EncodeElement(m.MergeCells, semergeCells)
|
|
}
|
|
if m.PhoneticPr != nil {
|
|
sephoneticPr := xml.StartElement{Name: xml.Name{Local: "x:phoneticPr"}}
|
|
e.EncodeElement(m.PhoneticPr, sephoneticPr)
|
|
}
|
|
if m.ConditionalFormatting != nil {
|
|
seconditionalFormatting := xml.StartElement{Name: xml.Name{Local: "x:conditionalFormatting"}}
|
|
e.EncodeElement(m.ConditionalFormatting, seconditionalFormatting)
|
|
}
|
|
if m.DataValidations != nil {
|
|
sedataValidations := xml.StartElement{Name: xml.Name{Local: "x:dataValidations"}}
|
|
e.EncodeElement(m.DataValidations, sedataValidations)
|
|
}
|
|
if m.Hyperlinks != nil {
|
|
sehyperlinks := xml.StartElement{Name: xml.Name{Local: "x:hyperlinks"}}
|
|
e.EncodeElement(m.Hyperlinks, sehyperlinks)
|
|
}
|
|
if m.PrintOptions != nil {
|
|
seprintOptions := xml.StartElement{Name: xml.Name{Local: "x:printOptions"}}
|
|
e.EncodeElement(m.PrintOptions, seprintOptions)
|
|
}
|
|
if m.PageMargins != nil {
|
|
sepageMargins := xml.StartElement{Name: xml.Name{Local: "x:pageMargins"}}
|
|
e.EncodeElement(m.PageMargins, sepageMargins)
|
|
}
|
|
if m.PageSetup != nil {
|
|
sepageSetup := xml.StartElement{Name: xml.Name{Local: "x:pageSetup"}}
|
|
e.EncodeElement(m.PageSetup, sepageSetup)
|
|
}
|
|
if m.HeaderFooter != nil {
|
|
seheaderFooter := xml.StartElement{Name: xml.Name{Local: "x:headerFooter"}}
|
|
e.EncodeElement(m.HeaderFooter, seheaderFooter)
|
|
}
|
|
if m.RowBreaks != nil {
|
|
serowBreaks := xml.StartElement{Name: xml.Name{Local: "x:rowBreaks"}}
|
|
e.EncodeElement(m.RowBreaks, serowBreaks)
|
|
}
|
|
if m.ColBreaks != nil {
|
|
secolBreaks := xml.StartElement{Name: xml.Name{Local: "x:colBreaks"}}
|
|
e.EncodeElement(m.ColBreaks, secolBreaks)
|
|
}
|
|
if m.CustomProperties != nil {
|
|
secustomProperties := xml.StartElement{Name: xml.Name{Local: "x:customProperties"}}
|
|
e.EncodeElement(m.CustomProperties, secustomProperties)
|
|
}
|
|
if m.CellWatches != nil {
|
|
secellWatches := xml.StartElement{Name: xml.Name{Local: "x:cellWatches"}}
|
|
e.EncodeElement(m.CellWatches, secellWatches)
|
|
}
|
|
if m.IgnoredErrors != nil {
|
|
seignoredErrors := xml.StartElement{Name: xml.Name{Local: "x:ignoredErrors"}}
|
|
e.EncodeElement(m.IgnoredErrors, seignoredErrors)
|
|
}
|
|
if m.SmartTags != nil {
|
|
sesmartTags := xml.StartElement{Name: xml.Name{Local: "x:smartTags"}}
|
|
e.EncodeElement(m.SmartTags, sesmartTags)
|
|
}
|
|
if m.Drawing != nil {
|
|
sedrawing := xml.StartElement{Name: xml.Name{Local: "x:drawing"}}
|
|
e.EncodeElement(m.Drawing, sedrawing)
|
|
}
|
|
if m.LegacyDrawing != nil {
|
|
selegacyDrawing := xml.StartElement{Name: xml.Name{Local: "x:legacyDrawing"}}
|
|
e.EncodeElement(m.LegacyDrawing, selegacyDrawing)
|
|
}
|
|
if m.LegacyDrawingHF != nil {
|
|
selegacyDrawingHF := xml.StartElement{Name: xml.Name{Local: "x:legacyDrawingHF"}}
|
|
e.EncodeElement(m.LegacyDrawingHF, selegacyDrawingHF)
|
|
}
|
|
if m.DrawingHF != nil {
|
|
sedrawingHF := xml.StartElement{Name: xml.Name{Local: "x:drawingHF"}}
|
|
e.EncodeElement(m.DrawingHF, sedrawingHF)
|
|
}
|
|
if m.Picture != nil {
|
|
sepicture := xml.StartElement{Name: xml.Name{Local: "x:picture"}}
|
|
e.EncodeElement(m.Picture, sepicture)
|
|
}
|
|
if m.OleObjects != nil {
|
|
seoleObjects := xml.StartElement{Name: xml.Name{Local: "x:oleObjects"}}
|
|
e.EncodeElement(m.OleObjects, seoleObjects)
|
|
}
|
|
if m.Controls != nil {
|
|
secontrols := xml.StartElement{Name: xml.Name{Local: "x:controls"}}
|
|
e.EncodeElement(m.Controls, secontrols)
|
|
}
|
|
if m.WebPublishItems != nil {
|
|
sewebPublishItems := xml.StartElement{Name: xml.Name{Local: "x:webPublishItems"}}
|
|
e.EncodeElement(m.WebPublishItems, sewebPublishItems)
|
|
}
|
|
if m.TableParts != nil {
|
|
setableParts := xml.StartElement{Name: xml.Name{Local: "x:tableParts"}}
|
|
e.EncodeElement(m.TableParts, setableParts)
|
|
}
|
|
if m.ExtLst != nil {
|
|
seextLst := xml.StartElement{Name: xml.Name{Local: "x:extLst"}}
|
|
e.EncodeElement(m.ExtLst, seextLst)
|
|
}
|
|
e.EncodeToken(xml.EndElement{Name: start.Name})
|
|
return nil
|
|
}
|
|
func (m *CT_Worksheet) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error {
|
|
// initialize to default
|
|
m.SheetData = NewCT_SheetData()
|
|
lCT_Worksheet:
|
|
for {
|
|
tok, err := d.Token()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
switch el := tok.(type) {
|
|
case xml.StartElement:
|
|
switch el.Name.Local {
|
|
case "sheetPr":
|
|
m.SheetPr = NewCT_SheetPr()
|
|
if err := d.DecodeElement(m.SheetPr, &el); err != nil {
|
|
return err
|
|
}
|
|
case "dimension":
|
|
m.Dimension = NewCT_SheetDimension()
|
|
if err := d.DecodeElement(m.Dimension, &el); err != nil {
|
|
return err
|
|
}
|
|
case "sheetViews":
|
|
m.SheetViews = NewCT_SheetViews()
|
|
if err := d.DecodeElement(m.SheetViews, &el); err != nil {
|
|
return err
|
|
}
|
|
case "sheetFormatPr":
|
|
m.SheetFormatPr = NewCT_SheetFormatPr()
|
|
if err := d.DecodeElement(m.SheetFormatPr, &el); err != nil {
|
|
return err
|
|
}
|
|
case "cols":
|
|
tmp := NewCT_Cols()
|
|
if err := d.DecodeElement(tmp, &el); err != nil {
|
|
return err
|
|
}
|
|
m.Cols = append(m.Cols, tmp)
|
|
case "sheetData":
|
|
if err := d.DecodeElement(m.SheetData, &el); err != nil {
|
|
return err
|
|
}
|
|
case "sheetCalcPr":
|
|
m.SheetCalcPr = NewCT_SheetCalcPr()
|
|
if err := d.DecodeElement(m.SheetCalcPr, &el); err != nil {
|
|
return err
|
|
}
|
|
case "sheetProtection":
|
|
m.SheetProtection = NewCT_SheetProtection()
|
|
if err := d.DecodeElement(m.SheetProtection, &el); err != nil {
|
|
return err
|
|
}
|
|
case "protectedRanges":
|
|
m.ProtectedRanges = NewCT_ProtectedRanges()
|
|
if err := d.DecodeElement(m.ProtectedRanges, &el); err != nil {
|
|
return err
|
|
}
|
|
case "scenarios":
|
|
m.Scenarios = NewCT_Scenarios()
|
|
if err := d.DecodeElement(m.Scenarios, &el); err != nil {
|
|
return err
|
|
}
|
|
case "autoFilter":
|
|
m.AutoFilter = NewCT_AutoFilter()
|
|
if err := d.DecodeElement(m.AutoFilter, &el); err != nil {
|
|
return err
|
|
}
|
|
case "sortState":
|
|
m.SortState = NewCT_SortState()
|
|
if err := d.DecodeElement(m.SortState, &el); err != nil {
|
|
return err
|
|
}
|
|
case "dataConsolidate":
|
|
m.DataConsolidate = NewCT_DataConsolidate()
|
|
if err := d.DecodeElement(m.DataConsolidate, &el); err != nil {
|
|
return err
|
|
}
|
|
case "customSheetViews":
|
|
m.CustomSheetViews = NewCT_CustomSheetViews()
|
|
if err := d.DecodeElement(m.CustomSheetViews, &el); err != nil {
|
|
return err
|
|
}
|
|
case "mergeCells":
|
|
m.MergeCells = NewCT_MergeCells()
|
|
if err := d.DecodeElement(m.MergeCells, &el); err != nil {
|
|
return err
|
|
}
|
|
case "phoneticPr":
|
|
m.PhoneticPr = NewCT_PhoneticPr()
|
|
if err := d.DecodeElement(m.PhoneticPr, &el); err != nil {
|
|
return err
|
|
}
|
|
case "conditionalFormatting":
|
|
tmp := NewCT_ConditionalFormatting()
|
|
if err := d.DecodeElement(tmp, &el); err != nil {
|
|
return err
|
|
}
|
|
m.ConditionalFormatting = append(m.ConditionalFormatting, tmp)
|
|
case "dataValidations":
|
|
m.DataValidations = NewCT_DataValidations()
|
|
if err := d.DecodeElement(m.DataValidations, &el); err != nil {
|
|
return err
|
|
}
|
|
case "hyperlinks":
|
|
m.Hyperlinks = NewCT_Hyperlinks()
|
|
if err := d.DecodeElement(m.Hyperlinks, &el); err != nil {
|
|
return err
|
|
}
|
|
case "printOptions":
|
|
m.PrintOptions = NewCT_PrintOptions()
|
|
if err := d.DecodeElement(m.PrintOptions, &el); err != nil {
|
|
return err
|
|
}
|
|
case "pageMargins":
|
|
m.PageMargins = NewCT_PageMargins()
|
|
if err := d.DecodeElement(m.PageMargins, &el); err != nil {
|
|
return err
|
|
}
|
|
case "pageSetup":
|
|
m.PageSetup = NewCT_PageSetup()
|
|
if err := d.DecodeElement(m.PageSetup, &el); err != nil {
|
|
return err
|
|
}
|
|
case "headerFooter":
|
|
m.HeaderFooter = NewCT_HeaderFooter()
|
|
if err := d.DecodeElement(m.HeaderFooter, &el); err != nil {
|
|
return err
|
|
}
|
|
case "rowBreaks":
|
|
m.RowBreaks = NewCT_PageBreak()
|
|
if err := d.DecodeElement(m.RowBreaks, &el); err != nil {
|
|
return err
|
|
}
|
|
case "colBreaks":
|
|
m.ColBreaks = NewCT_PageBreak()
|
|
if err := d.DecodeElement(m.ColBreaks, &el); err != nil {
|
|
return err
|
|
}
|
|
case "customProperties":
|
|
m.CustomProperties = NewCT_CustomProperties()
|
|
if err := d.DecodeElement(m.CustomProperties, &el); err != nil {
|
|
return err
|
|
}
|
|
case "cellWatches":
|
|
m.CellWatches = NewCT_CellWatches()
|
|
if err := d.DecodeElement(m.CellWatches, &el); err != nil {
|
|
return err
|
|
}
|
|
case "ignoredErrors":
|
|
m.IgnoredErrors = NewCT_IgnoredErrors()
|
|
if err := d.DecodeElement(m.IgnoredErrors, &el); err != nil {
|
|
return err
|
|
}
|
|
case "smartTags":
|
|
m.SmartTags = NewCT_SmartTags()
|
|
if err := d.DecodeElement(m.SmartTags, &el); err != nil {
|
|
return err
|
|
}
|
|
case "drawing":
|
|
m.Drawing = NewCT_Drawing()
|
|
if err := d.DecodeElement(m.Drawing, &el); err != nil {
|
|
return err
|
|
}
|
|
case "legacyDrawing":
|
|
m.LegacyDrawing = NewCT_LegacyDrawing()
|
|
if err := d.DecodeElement(m.LegacyDrawing, &el); err != nil {
|
|
return err
|
|
}
|
|
case "legacyDrawingHF":
|
|
m.LegacyDrawingHF = NewCT_LegacyDrawing()
|
|
if err := d.DecodeElement(m.LegacyDrawingHF, &el); err != nil {
|
|
return err
|
|
}
|
|
case "drawingHF":
|
|
m.DrawingHF = NewCT_DrawingHF()
|
|
if err := d.DecodeElement(m.DrawingHF, &el); err != nil {
|
|
return err
|
|
}
|
|
case "picture":
|
|
m.Picture = NewCT_SheetBackgroundPicture()
|
|
if err := d.DecodeElement(m.Picture, &el); err != nil {
|
|
return err
|
|
}
|
|
case "oleObjects":
|
|
m.OleObjects = NewCT_OleObjects()
|
|
if err := d.DecodeElement(m.OleObjects, &el); err != nil {
|
|
return err
|
|
}
|
|
case "controls":
|
|
m.Controls = NewCT_Controls()
|
|
if err := d.DecodeElement(m.Controls, &el); err != nil {
|
|
return err
|
|
}
|
|
case "webPublishItems":
|
|
m.WebPublishItems = NewCT_WebPublishItems()
|
|
if err := d.DecodeElement(m.WebPublishItems, &el); err != nil {
|
|
return err
|
|
}
|
|
case "tableParts":
|
|
m.TableParts = NewCT_TableParts()
|
|
if err := d.DecodeElement(m.TableParts, &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 %v", el.Name)
|
|
if err := d.Skip(); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
case xml.EndElement:
|
|
break lCT_Worksheet
|
|
case xml.CharData:
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
func (m *CT_Worksheet) Validate() error {
|
|
return m.ValidateWithPath("CT_Worksheet")
|
|
}
|
|
func (m *CT_Worksheet) ValidateWithPath(path string) error {
|
|
if m.SheetPr != nil {
|
|
if err := m.SheetPr.ValidateWithPath(path + "/SheetPr"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.Dimension != nil {
|
|
if err := m.Dimension.ValidateWithPath(path + "/Dimension"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.SheetViews != nil {
|
|
if err := m.SheetViews.ValidateWithPath(path + "/SheetViews"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.SheetFormatPr != nil {
|
|
if err := m.SheetFormatPr.ValidateWithPath(path + "/SheetFormatPr"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
for i, v := range m.Cols {
|
|
if err := v.ValidateWithPath(fmt.Sprintf("%s/Cols[%d]", path, i)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if err := m.SheetData.ValidateWithPath(path + "/SheetData"); err != nil {
|
|
return err
|
|
}
|
|
if m.SheetCalcPr != nil {
|
|
if err := m.SheetCalcPr.ValidateWithPath(path + "/SheetCalcPr"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.SheetProtection != nil {
|
|
if err := m.SheetProtection.ValidateWithPath(path + "/SheetProtection"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.ProtectedRanges != nil {
|
|
if err := m.ProtectedRanges.ValidateWithPath(path + "/ProtectedRanges"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.Scenarios != nil {
|
|
if err := m.Scenarios.ValidateWithPath(path + "/Scenarios"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.AutoFilter != nil {
|
|
if err := m.AutoFilter.ValidateWithPath(path + "/AutoFilter"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.SortState != nil {
|
|
if err := m.SortState.ValidateWithPath(path + "/SortState"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.DataConsolidate != nil {
|
|
if err := m.DataConsolidate.ValidateWithPath(path + "/DataConsolidate"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.CustomSheetViews != nil {
|
|
if err := m.CustomSheetViews.ValidateWithPath(path + "/CustomSheetViews"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.MergeCells != nil {
|
|
if err := m.MergeCells.ValidateWithPath(path + "/MergeCells"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.PhoneticPr != nil {
|
|
if err := m.PhoneticPr.ValidateWithPath(path + "/PhoneticPr"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
for i, v := range m.ConditionalFormatting {
|
|
if err := v.ValidateWithPath(fmt.Sprintf("%s/ConditionalFormatting[%d]", path, i)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.DataValidations != nil {
|
|
if err := m.DataValidations.ValidateWithPath(path + "/DataValidations"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.Hyperlinks != nil {
|
|
if err := m.Hyperlinks.ValidateWithPath(path + "/Hyperlinks"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.PrintOptions != nil {
|
|
if err := m.PrintOptions.ValidateWithPath(path + "/PrintOptions"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.PageMargins != nil {
|
|
if err := m.PageMargins.ValidateWithPath(path + "/PageMargins"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.PageSetup != nil {
|
|
if err := m.PageSetup.ValidateWithPath(path + "/PageSetup"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.HeaderFooter != nil {
|
|
if err := m.HeaderFooter.ValidateWithPath(path + "/HeaderFooter"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.RowBreaks != nil {
|
|
if err := m.RowBreaks.ValidateWithPath(path + "/RowBreaks"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.ColBreaks != nil {
|
|
if err := m.ColBreaks.ValidateWithPath(path + "/ColBreaks"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.CustomProperties != nil {
|
|
if err := m.CustomProperties.ValidateWithPath(path + "/CustomProperties"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.CellWatches != nil {
|
|
if err := m.CellWatches.ValidateWithPath(path + "/CellWatches"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.IgnoredErrors != nil {
|
|
if err := m.IgnoredErrors.ValidateWithPath(path + "/IgnoredErrors"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.SmartTags != nil {
|
|
if err := m.SmartTags.ValidateWithPath(path + "/SmartTags"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.Drawing != nil {
|
|
if err := m.Drawing.ValidateWithPath(path + "/Drawing"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.LegacyDrawing != nil {
|
|
if err := m.LegacyDrawing.ValidateWithPath(path + "/LegacyDrawing"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.LegacyDrawingHF != nil {
|
|
if err := m.LegacyDrawingHF.ValidateWithPath(path + "/LegacyDrawingHF"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.DrawingHF != nil {
|
|
if err := m.DrawingHF.ValidateWithPath(path + "/DrawingHF"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.Picture != nil {
|
|
if err := m.Picture.ValidateWithPath(path + "/Picture"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.OleObjects != nil {
|
|
if err := m.OleObjects.ValidateWithPath(path + "/OleObjects"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.Controls != nil {
|
|
if err := m.Controls.ValidateWithPath(path + "/Controls"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.WebPublishItems != nil {
|
|
if err := m.WebPublishItems.ValidateWithPath(path + "/WebPublishItems"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.TableParts != nil {
|
|
if err := m.TableParts.ValidateWithPath(path + "/TableParts"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.ExtLst != nil {
|
|
if err := m.ExtLst.ValidateWithPath(path + "/ExtLst"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|