Class: RubyXL::OOXMLTopLevelObject
- Inherits:
-
OOXMLObject
- Object
- OOXMLObject
- RubyXL::OOXMLTopLevelObject
- Defined in:
- lib/rubyXL/objects/ooxml_object.rb
Overview
Extension class providing functionality for top-level OOXML objects that are represented by their own .xml files in .xslx zip container.
Direct Known Subclasses
CalculationChain, Chartsheet, CommentsFile, ContentTypes, CorePropertiesFile, DocumentPropertiesFile, OOXMLRelationshipsFile, SharedStringsTable, Stylesheet, Theme, Workbook, Worksheet
Constant Summary collapse
- SAVE_ORDER =
500
Class Method Summary collapse
-
.parse_file(dirpath, file_path = nil) ⇒ Object
Generates the top-level OOXML object by parsing its XML file from the temporary directory containing the unzipped contents of
.xslx=== Parameters *dirpath- path to the directory with the unzipped.xslxcontents. -
.set_namespaces(namespace_hash) ⇒ Object
Sets the list of namespaces on this object to be added when writing out XML.
Instance Method Summary collapse
-
#add_to_zip(zip_stream) ⇒ Object
Saves the contents of the object as XML to respective location in
.xslxzip container. - #file_index ⇒ Object
-
#xlsx_path ⇒ Object
Prototype method.
Methods included from OOXMLObjectClassMethods
#define_attribute, #define_child_node, #define_element_name, #obtain_class_variable, #parse
Methods included from OOXMLObjectInstanceMethods
#before_write_xml, #dup, #index_in_collection, #initialize, #write_xml
Class Method Details
.parse_file(dirpath, file_path = nil) ⇒ Object
Generates the top-level OOXML object by parsing its XML file from the temporary directory containing the unzipped contents of .xslx
Parameters
-
dirpath- path to the directory with the unzipped.xslxcontents.
419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 |
# File 'lib/rubyXL/objects/ooxml_object.rb', line 419 def self.parse_file(dirpath, file_path = nil) file_path = ::Pathname.new(file_path || self.xlsx_path) case dirpath when String then full_path = File.join(dirpath, file_path) return nil unless File.exist?(full_path) # Making sure that the file will be automatically closed immediately after it has been read File.open(full_path, 'r') { |f| parse(f) } when Zip::File then file_path = file_path.relative_path_from(::Pathname.new("/")) if file_path.absolute? # Zip doesn't like absolute paths. entry = dirpath.find_entry(file_path) # Accomodate for Nokogiri Java implementation which is incapable of reading from a stream entry && (entry.get_input_stream { |f| parse(defined?(JRUBY_VERSION) ? f.read : f) }) end end |
.set_namespaces(namespace_hash) ⇒ Object
Sets the list of namespaces on this object to be added when writing out XML. Valid only on top-level objects.
Parameters
-
namespace_hash- Hash of namespaces in the form of"prefix" => "url"
Examples
set_namespaces('http://schemas.openxmlformats.org/spreadsheetml/2006/main' => '',
'http://schemas.openxmlformats.org/officeDocument/2006/relationships' => 'r')
411 412 413 |
# File 'lib/rubyXL/objects/ooxml_object.rb', line 411 def self.set_namespaces(namespace_hash) self.class_variable_set(:@@ooxml_namespaces, namespace_hash) end |
Instance Method Details
#add_to_zip(zip_stream) ⇒ Object
Saves the contents of the object as XML to respective location in .xslx zip container.
Parameters
-
zipfile- ::Zip::File to which the resulting XNMML should be added.
439 440 441 442 443 444 |
# File 'lib/rubyXL/objects/ooxml_object.rb', line 439 def add_to_zip(zip_stream) xml_string = write_xml return if xml_string.empty? zip_stream.put_next_entry(self.xlsx_path) zip_stream.write(xml_string) end |
#file_index ⇒ Object
446 447 448 |
# File 'lib/rubyXL/objects/ooxml_object.rb', line 446 def file_index @workbook.root.rels_hash[self.class].index{ |f| f.equal?(self) }.to_i + 1 end |
#xlsx_path ⇒ Object
Prototype method. For top-level OOXML object, returns the path at which the current object’s XML file is located within the .xslx zip container.
401 402 403 |
# File 'lib/rubyXL/objects/ooxml_object.rb', line 401 def xlsx_path raise 'Subclass responsebility' end |