Revision history for Spreadsheet-XLSX-Reader-LibXML
Uses the change tracking convention
+ New feature.
- Removed/deprecated feature.
! Bug fix.
* Place holder
NOTE: This software is designated as beta quality until this notice is removed. The goal is to
be method matched to Spreadsheet::ParseExcel prior to the 1.0 release.
v0.38.14 2015-08-24 16:49:04-07:00 America/Los_Angeles
! re-closes #52 in github with the addtional testing suggested
! Fixed a bug with 'is_hidden' reporting at the cell level tested by 07-losing_is_hidden_bug.t
! Changed the %INC test to an %ENV test and turn on the like_ParseExcel flag with
$ENV{SPREADSHEET_READ_XLSX} == "Spreadsheet::XLSX::Reader::LibXML"
This is a more accurate flag test for use by Spreadsheet::Read
v0.38.12 2015-08-19 05:19:28-07:00 America/Los_Angeles
+ Fix yet another bug in the hidden formatting (hopefully)
+ Make the decimal vs scientific choice for hidden formatting more robust( issue 65 on github )
+ Adding tests for hidden tabs rows columns and cells in the worksheet and cell
+ Adding the method 'get_merged_areas' to match ~::ParseExcel
+ For compatability purposes this package will now test (during import) to see if it's being
used in Spreadsheet::Read (potential future) and automatically push the :like_ParseExcel
tag on the end of the tag list so that it will behave consistently to ParseExcel for a common
reader. (This is a beta feature and not guaranteed to remain)
+ This package now supports stacked flags (not that there exists so many already)
The purpose of this is as I run into additional use cases the intersection of
the flags I support and the flags that are desired by the user may require some juggling.
Where flags disagree in their defaults the last flag passed will be used. This should allow
for the proliferation of flags for specialty cases without having to explicitly build one
for each use case. (At some point though you may just want to use the attributes).
The test for this is t/Spreadsheet/XLSX/Reader/06-stacked_flags.t
v0.38.10 2015-08-10 21:43:11-07:00 America/Los_Angeles
! Fix TravisCI build fail on test 60-hidden_format_strings.t
! Closes #60 in github
! Exclude text to sprintf number test bug
! Added a return the 'xml_value' only option to the 'group_return_type' attribute
v0.38.9 2015-08-06 13:45:36-07:00 America/Los_Angeles
! Closes #57 in github missing LICENSE file
v0.38.8 2015-08-05 11:15:01-07:00 America/Los_Angeles
! Re-Dist::Zilla build with the version badge corrected
! Closes #51 in github
This includes autoformatting of scientific numbers to the least significant digit in 9 positions
scientific number autoformatting is an excel application function that occurs even in the absence of applied formats
This includes some exclusion of scientific number like strings
+ Added the cell_xml_value attribute and methods to give access to the base scientific notiation data where
Excel would mangle it or make it potentially less precise even in an unformtted raw value thanks @Tux for the test case
+ Added support for the old(old) Excel style single quote in the formula bar representing left justification
! Closes #49 in github
+ Expanded the file type allowance to include capitalized file extentions
v0.38.6 2015-06-30 06:13:36-07:00 America/Los_Angeles
! Some general documentation updates for the FmtDefault class that were not done correctly for the last release
Doh!
+ Added the possibility of passing a closure to the set_headers for header value scrubbing
+ Adjusted the :just_the_data flag
cache_positions => 1, (documented as added but not added last commit)
from_the_edge => 0,
v0.38.4 2015-06-29 17:17:07-07:00 America/Los_Angeles
! The first Alien::LibXML change failed - trying again
v0.38.2 2015-06-29 16:45:47-07:00 America/Los_Angeles
+ Added a cache_positions flag to the Workbook level
For now this only populates to cache built number conversion and the shared strings file
+ 'set_custom_formats' now has built in coercion to change Excel strings to coercion objects
This allows for you to define custom excel column formatting (Not already defined in the file)
using excel strings without building an intermediate coersion before loading it to the worksheet.
+ I changed the custom_formats attribute to _custom_formats in order to indicate that it
should be set via the 'set_custom_formats' method
+ The worksheet class now accepts Excel format strings rather than requireing that the custom coercions be pre-built
(This is worksheet level functionality not workbook level functionality - still)
+ added the ability to only return portions of a node with a specific tag name to Spreadsheet::XLSX::Reader::LibXML::XMLReader::XMLToPerlData
This should be activated for the SharedStrings file whenever the workbook attribute 'group_return_type' is set to 'unformatted' or 'value'
The goal for this is to see a speed boost
Closes #47 in github
+ Added a cache_positions flag to the SharedStrings class
The goal is to see a speed boost for sheets with a large number of text strings
Like perl hash keys, shared strings are not ordered by cell
This means for files with lots of stored text each shared strings position is only read once instead of rewinding and re-searching
The new behaviour is managed by the SharedStrings class attribute 'cache_positions' (default on)
Setting cache_positions => 0 should return the old behaviour
If there is only text in the position then the cache only stores the text to minimize RAM impact
Additionally as a trade off for the increased RAM usage the sharedStrings file is closed after it has been completely read once
I will only read as far into shared strings as you ask (reading one value and then closing the sheet will only read to that value)
It will slow the first values out down but overall speed the reading of lots of values
Sheets with only numbers will not be affected
Closes #46 in github
+ Changed the cell formatter from a Role to a Class to match Spreadsheet::ParseExcel
THIS IS A REALLY BIG CHANGE
The target is to integrate better with Spreadsheet::Read
Closes #45 in github
+ Reduced the implementation of Alien::LibXML in dist.ini to see if that affects the CPAN Testers takeup rate
v0.36.28 2015-06-24 14:41:34-07:00 America/Los_Angeles
+ Surpressed a misleading error when value coercion is not succesful
v0.36.26 2015-06-23 19:01:21-07:00 America/Los_Angeles
! Closed #42 in github
v0.36.24 2015-06-10 19:44:32-07:00 America/Los_Angeles
! Attempting to solve the deep recursion from TravisCI in the new bugfix
+ Added perl 5.22 to TravisCI testing
! Fixed the failing TravisCI build
v0.36.22 2015-06-10 17:11:39-07:00 America/Los_Angeles
! Closed #40 in github thanks @wdbaker54
v0.36.20 2015-04-21 14:30:58-07:00 America/Los_Angeles
! Fixed the "this version" badge
! fixed some uninitialized values thrown by travis-ci
v0.36.18 2015-04-05 21:44:26-07:00 America/Los_Angeles
! Giving up on the javascript if statement (github strips 'script' tags and content)
v0.36_17 2015-04-03 23:37:22-07:00 America/Los_Angeles
! Test of the javascript changes to see if I can get it to be included
v0.36.16 2015-04-03 22:27:06-07:00 America/Los_Angeles
+ Added some javascript to the badges html to distinguish from a cpan domain so
versions only show on github
v0.36.14 2015-04-02 13:22:11-07:00 America/Los_Angeles
+ moved the current version to a badge and tweaked the badges to see what happens
v0.36.12 2015-04-02 11:45:08-07:00 America/Los_Angeles
! Updated the documentation in preparation for a push all the way to CPAN since
TravisCI builds are passing.
! Changed the MakeMaker call from setting CFLAGS to setting CCFLAGS
v0.36.10 2015-04-02 11:02:47-07:00 America/Los_Angeles
! Moved the Alien::LibXML requirement to the configure stage to try and pass a TavisCI build
v0.36.8 2015-04-02 10:58:17-07:00 America/Los_Angeles
! Rewrote the dist.ini so that Makefile.PL should implement Alien::LibXML correctly
v0.36.6 2015-03-31 19:48:28-07:00 America/Los_Angeles
+ Added a version header to the primary pod
+ Added the cpan version badge and a badge header
v0.36.2 2015-03-31 08:13:56-07:00 America/Los_Angeles
+ Added badges (Thanks @GARU)
+ Added Alien::LibXML as a requirement in MakeFile.PL to see if there was any impact
! Removed TODO #6 (I already did it)
v0.34.6 2015-03-13 22:44:41-07:00 America/Los_Angeles
! Closed #6 in github by writing POD for Spreadsheet::XLSX::Reader::LibXML::XMLReader
! Closed #7 in github by writing POD for Spreadsheet::XLSX::Reader::LibXML::XMLReader::SharedStrings
! Closed #8 in github by writing POD for Spreadsheet::XLSX::Reader::LibXML::XMLReader::Worksheet
! Closed #9 in github by writing POD for Spreadsheet::XLSX::Reader::LibXML::XMLReader::XMLToPerlData
+ added an 'alt_default' flag so that behaviour different than the Spreadsheet::ParseExcel would be easy
and closed #31 in github
v0.34.4 2015-02-20 09:41:28-08:00 America/Los_Angeles
! Closed #32 in github by creating a separation of chartsheet reading from worksheet
reading. I also found a read sheets more than once bug and fixed it along the way (thanks @morungos)
! Wrote POD for Types.pm module and closed #5 in github
v0.34.2 2015-02-14 08:28:33-08:00 America/Los_Angeles
! Scrubbed exising pod for cruft and closed #13 issue in github
! Improved the contributors section
! Re-orderd the changes section from bottom to top rather than top to bottom
! Moved the 'next' row function for empty requests for fetchrow_arrayref to
Spreadsheet::XLSX::Reader::LibXML::XMLReader::Worksheet from ~LibXML::GetCell
+ moved the xml_reader attribute from ~XMLReader to private and changed the
file_name attribute to coerce to a file handle and then build the xml_reader
in the background
+ Closed #27 in github by removing some cruft in the worksheet build (Thank you Frank Maas)
+ Closed #26 in github by manageing the variable out rather that messing with the variable in
This includes adding a possible test for the old failure in 10-get_cell.t (Thank you Frank Maas)
+ Added test 04-no_pivot_bug.t in response to issue #24 (pull request)
This test actually uncovered two issues with the simple implementation and both are fixed
The second issue is with a Styles sheet with no number formats listed
The third issue is with worksheet ranges that only have one cell. (Thank you Frank Maas)
! Fixed the bug where there are no shared strings in the excel file (Thank you Frank Maas)
! Closed #29 in github with a substantial rework of XMLToPerlData.pm (Thank you Frank Maas)
The module API and target results didn't change
+ Closed #30 in github by adding the 'values_only' attribute
documentation is found in the top level README
! Cleaned up a few more bugs found along the way
! Wrote POD for Styles.pod module and closed #12 in github
! Wrote POD for SharedStrings.pod module and closed #11 in github
! Wrote POD for XMLReader::Styles.pm module and closed #10 in github
v0.34.0 2014-12-29 08:49:14-08:00 America/Los_Angeles
! Closed #22 issue in github by adding the requirement for Type::Tiny 1.000 (vs 0.046)
to implement make_immutable in the type library
+ Scrubbed Spreadsheet::XLSX::Reader::LibXML POD to comply better with updates
v0.32.2 2014-12-26 16:25:30-08:00 America/Los_Angeles
! Closed #21 issue in github with error objects vs error strings - solved with a type coercion
v0.30.2 2014-12-25 21:25:32-08:00 America/Los_Angeles
! Closed #20 in github (pull request for undef FileType message specificity)
+ Closed #3 in github Move Temp::Dir methods to Archive::Zip in github
This is a big change since it changes some of the extensibility API's
It also changes the way the initial file is locked. It used to unzip the file to a
temporory directory and then unlock the file. Now it holds a lock on the file during the whole read.
! Closed #18 in github. The temp dir management is very different
The failing solo SciTE GUI test 03-temp_dir_bug.t now passes.
v0.30.0 2014-12-15 12:51:23-08:00 America/Los_Angeles
+ Closed #16 in github by moving the role Spreadsheet::XLSX::Reader::LibXML::LogSpace to Log::Shiras::LogSpace
and moving all the attribute callouts behind ###LogSD comments
+ Closed #19 in github by expanding the allowed width of the match data reference pointer when checking the
answer for specific errors
v0.28.2 2014-12-13 20:30:26-08:00 America/Los_Angeles
! Fixed #15 issue in github (Return precedence error)
- Closed #2 issue in github (Remove the OLE::Storage_lite dependancy)
! Closes #17 in github (Allow parse to accept either a file name or a file handle)
+ Added a file_handle attribute to support passing either file handles or file names
+ Improved the test file 01-types.t to include coercions and error message checking
v0.26.2 2014-12-11 08:57:26-08:00 America/Los_Angeles
! Fixed the 'requires missing role' bug (github issue -> missing role?)
v0.24.2 2014-12-09 05:18:13-08:00 America/Los_Angeles
+ added the empty_return_type attribute so that this package will emulate ParseExcel
You can still choose to return undef by setting this attribute to 'undef_string'
! added another fix in the cleanup since it forced a fail when fails weren't needed
v0.22.2 2014-12-04 15:46:15-08:00 America/Los_Angeles
! Fixed a bug in the error reporting for the value method in the cell
! Fixed a bug where the sheet position wasn't set correctly when calling for worksheet generation by name
added a test file for this case
! Improved temp dir cleanup in error situations - with less code
this inclues a new explicit DEMOLISH at the cell level
v0.20.4 2014-12-03 13:27:23-08:00 America/Los_Angeles
+ A round of POD scrubbing for POD completed to this point
v0.20.2 2014-12-02 12:56:46-08:00 America/Los_Angeles
+ Finished the POD for ParseExcelFormatStrings.pm
+ Merged UtilFunctions with ParseExcelFormatStrings since there was no reason
for them to be separate
+ Improved the POD for GetCell.pm
+ made the methods for clearing the row reading start and end column definitions public
v0.18.2 2014-11-30 13:54:00-08:00 America/Los_Angeles
! Although the last update had more passes on CPAN testers this is another update
attempting to reach 100% pass rate
v0.16.2 2014-11-29 16:43:29-08:00 America/Los_Angeles
+ Some tweaks to the LibXML POD
! Another re-write of the ParseExcelFormatStrings.pm to try and fix CPAN Testers fails
v0.14.2 2014-11-26 21:52:22-08:00 America/Los_Angeles
! Fixed a 32bit precision issue
v0.12.4 2014-11-26 06:45:17-08:00 America/Los_Angeles
! Removed the regex match within a regex test to pass older perls in test
v0.12.2 2014-11-26 06:06:30-08:00 America/Los_Angeles
+ Improved the FmtDefault POD
+ Improved the LibXML POD
+ Extracted several elements of cruft from Types
+ Reworked the ParseExcelFormatStrings to run on Dispatch Tables for improved consistency
and to hopefully address CPAN testers fails
+ moved the change_output_encoding out of ParseExcelFormatStrings an into the cell and value
v0.10.6 2014-11-18 16:46:07-08:00 America/Los_Angeles
! Fixed several errors in the CellToColumnRow POD
+ Improved the Error POD
+ More tweaks to the LibXML POD
! Fixed a precision bug in ParseExcelFormatStrings
calls for more universal implementation.
v0.10.4 2014-11-16 09:35:36-08:00 America/Los_Angeles
+ Improved CellToColumnRow POD
+ Improved the top level POD
+ Improved the Worksheet POD
! Removed the SVPerlTalk.odp from the package (as bloat)
Look in the github repository if you want to review it
+ Added a new POD file for the SharedStrings class (to be universal across Reader and DOM)
+ Added a new POD file for the Styles class (to be universal across Reader and DOM)
+ Added a new POD file for the CalcChain class (to be universal across Reader and DOM)
v0.10.2 2014-11-13 10:29:27-08:00 America/Los_Angeles
+ Fixed and updated the POD based on a MetaCPAN read
v0.10.1 2014-11-13 05:37:32-08:00 America/Los_Angeles
+ Finished the Worksheet POD
+ Completed the Cell POD
+ Completed the Error POD
+ Completed the CellToColumnRow POD
+ Another (but not final0 proofread of the Spreadsheet::XLSX::Reader::LibXML POD
+ Release with a Beta rev to try and Index on MetaCPAN
v0.7_1 2014-11-12 07:41:39-08:00 America/Los_Angeles
+ POD for the main module complete
+ Improved POD for the worksheet module
v0.5_1 2014-11-07 08:23:08-08:00 America/Los_Angeles
+ Initial near CPAN ready release with a full test suit for cross platform testing
+ Changed the Cell class to be just an encapulated data holder
! Fixed the resources links in the META files
+ Used type support from Type::Coercions to allow for data transformation definitions
! The documentation is all wrong. Next release I promise!
! Reader parsing support only
- DOM parsing contract dependant or some (possibly distant) time in the future
v0.1_1 2014-06-06 10:06:00-07:00 America/Los_Angeles
+ Initial (non-functional) github release