// 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 }