CHANGELOG ========= 0.3.3 ----- * [BUG FIX]Use UnpackedURI adapter for URI * [BREAKING CHANGE]Remove deprecated second argument from `EPUB::Parser::Publication#initialize` * Add `detect_encoding` keyword argument to `Publication::Package::Manifest::Item#read` and `ContentDocument::XHTML#read` 0.3.2 ----- * Use epub-cfi gem for EPUB CFI 0.3.1 ----- * Load epub/parser.rb in epub/parser/cfi.rb to allow to use Parser::CFI independently * Make `CFI` comparable. Now can call `CFI#==` * Include `Publication::Package::Spine::Itemref` in `Searcher.search_element`'s result 0.3.0 ----- * Wrong release. I'm sorry. 0.2.9 ----- * Fix a bug that `Searcher.search_element` returns wrong CFI * Add `Searcher.search_by_cfi` 0.2.8 ----- * Change Searcher API: #search -> #search_text * Add Searcher.search_element 0.2.7 ----- * Add `EPUB::Metadata#children` to keep all child emements to count them on CFI search * Allow class including `EPUB` to intialize with extra arguments(Thanks, [skukx][]!) [skukx]: https://github.com/skukx 0.2.6 ----- * Add `EPUB::Publication::Package::Metadata#package_identifier` as alias of `#release_identifier`, which is defined in EPUB Publication 3.0 spec * [BUG FIX]Metadata#modified returns modified with no refiners * Make second argument for `EPUB::Parser::Publication.new` deprecated * Add META-INF/metadata.xml support defined in [EPUB Multiple-Rendition Publications 1.0][multi-rendition] * Add `EPUB::Book::Features#packages` and `#default_rendition` * [BUG FIX]Don't raise error when using `Zipruby` container adapter [multi-rendition]: http://www.idpf.org/epub/renditions/multiple/ 0.2.5 ----- * [BUG FIX]Don't load Zip/Ruby if unneccessary * Raise error when PhysicalContainer::ArchiveZip fails find entry * Remove unused files in schemas directory * Add `EPUB::CFI::PhysicalContainer.find_adapter` 0.2.4 ----- * Bug fix for `EPUB::CFI::Location#<=>` * Change default physical container adapter from `EPUB::OCF::PhysicalContainer::ZipRuby` to `EPUB::OCF::PhysicalContainer::ArchiveZip` * Add `EPUB::CFI::Step#element?` and `#character_data?` * Change attribute name: `EPUB::CFI::Step#step` -> `EPUB::CFI::Step#value`, `EPUB::CFI::CharacterOffset#offset` -> `EPUB::CFI::CharacterOffset#value` * Show modified on `epubinfo` command 0.2.3 ----- * Change the name of physical container adapter for file system: :File -> :UnpackedDirectory * Add `EPUB::Publication::Package::Manifest::Item#full_path` * Make #href= acceptable String * Implement `EPUB::CFI` and `EPUB::Parser::CFI` * Remove [nokogumbo][] from dependencies. It ommits `head` and `body` elements * Remove Cucumber and Cucumber features * Add `EPUB::Publication::Package::Metadata#modified` and `EPUB::Book::Features#modified` * Add `EPUB::Book::Features#release_identifier` 0.2.2 ----- * [BUGFIX]Item#entry_name returns normalized IRI 0.2.1 ----- * Remove deprecated `EPUB::Constants::MediaType::UnsupportedError`. Use `UnsupportedMediatType` instead. * Make it possible to use [archive-zip][] gem to extract contents from EPUB package via `EPUB::OCF::PhysicalContainer::ArchiveZip` * Add warning about default physical container adapter change * Make it possible to extract contents from the web via `EPUB::OCF::PhysicalContainer::UnpackedURI`. See {file:ExtractContentsFromWeb.markdown} for details. [archive-zip]: https://github.com/javanthropus/archive-zip 0.2.0 ----- * Introduce abstraction layer for OCF physical container * Add `EPUB::OCF::PhysicalContainer::File` and make it possible to parse file system directory as an EPUB file. See {file:docs/UnpackedArchive.markdown} for details. * Remove `EPUB::Parser::OCF::CONTAINER_FILE` and other constants 0.1.9 ----- * Introduce [Nokogumbo][] for XHTML Content Documents * Stop support for Ruby 1.9 * Remove `EPUB.included` method. Now including `EPUB` module empowers nothing of EPUB features. Include `EPUB::Book::Features` instead. * Add `EPUB::Searcher::XHTML::Seamless` and make it default searcher * Add `EPUB::Publication::Package::Manifest#each_nav` * Stop to use enumerabler gem [nokogumbo]: https://github.com/rubys/nokogumbo/ 0.1.8 ----- * Explicity #close each zip member file that has been opened via #fopen(Thanks, [xunker][]!) [xunker]: https://github.com/xunker 0.1.7.1 ------- * Don't set encoding when content is not text 0.1.7 ----- * [Experimental]Add `EPUB::Searcher` module. See {file:Searcher.markdown} for details * Detect and set character encoding in `EPUB::Publication::Package::Item#read` 0.1.6 ----- * Remove `EPUB.parse` method * Remove `EPUB::Publication::Package::Metadata#to_hash` * Add `EPUB::Publication::Package::Metadata::Identifier` for ad-hoc `scheme` attribute and `#isbn?` method * Remove `MethodDecorators::Deprecated` * Make `EPUB::Parser::OCF::CONTAINER_FILE` and other constants deprecated * Make `EPUB::Publication::Package::Metadata::Link#rel` a `Set` * Add exception class `EPUB::Constants::MediaType::UnsupportedMediaType` * Make `EPUB::Constants::MediaType::UnsupportedError` deprecated. Use `UnsupportedMediatType` instead * Add `EPUB::Publication::Package::Item#cover_image?` * Add `EPUB::Book::Features` module and move methods of `EPUB` module to it(Thanks, [takahashim][]!) * Make including `EPUB` deprecated * Parse `hidden` attribute of `nav` elements * [Experimental]Add `EPUB::ContentDocument::Navigation::Item#traverse` [takahashim]: https://github.com/takahashim 0.1.5 ----- * Add `ContentDocument::XHTML#title` * Add `Manifest::Item#xhtml?` * Add `--words` and `--chars` options to `epubinfo` command which count words and charactors of XHTMLs in EPUB file * API change: `OCF::Container::Rootfile#full_path` became Addressable::URI object rather than `String`. `EPUB#rootfile_path` still returns `String` * Add `ContentDocument::XHTML#rexml` which returns document as `REXML::Document` object * Add `ContentDocument::XHTML#nokogiri` which returns document as `Nokogiri::XML::Document` object * Inspect more readbly 0.1.4 ----- * [Fixed-Layout Documents][fixed-layout] support * Define `ContentDocument::XHTML#top_level?` * Define `Spine::Itemref#page_spread` and `#page_spread=` * Define some utility methods around `Manifest::Item` and `Spine::Itemref` * `Manifest::Item#itemref` * `Spine::Itemref#item=` [fixed-layout]: http://www.idpf.org/epub/fxl/ 0.1.3 ----- * Add `EPUB::Parser::Utils` module * Add a command-line tool `epub-open` * Add support for XHTML Navigation Document * Make `EPUB::Publication::Package::Metadata#to_hash` obsolete. Use `#to_h` instead * Add utility methods `EPUB#description`, `EPUB#date` and `EPUB#unique_identifier` 0.1.2 ----- * Fix a bug that `Item#read` couldn't read file when `href` is percent-encoded(Thanks, [gambhiro][]!) [gambhiro]: https://github.com/gambhiro 0.1.1 ----- * Parse package@prefix and attach it as `Package#prefix` * `Manifest::Item#iri` was removed. It have existed for files in unzipped epub books but now EPUB Parser retrieves files from zip archive directly. `#href` now returns `Addressable::URI` object. * `Metadata::Link#iri`: ditto. * `Guide::Reference#iri`: ditto.