This document provides a high-level view of the changes to the Jekyll AsciiDoc Plugin by release. For a detailed view of what has changed, refer to the commit history on GitHub.
-
convert documentation from README.adoc to an Antora component in the Asciidoctor docs site. (#238)
-
bump requirements: Asciidoctor 2.0, Ruby 2.7, JRuby 9.4 (#237)
-
explain Liquid include interactions in docs (#223)
-
explain asciidoctor-diagram data-uri and svg options in docs (#217)
-
provide
asciidoc_docinfo
Liquid filter to allow including docinfo content in layouts (#164) -
correct excerpt hook handling so excerpts can be used with other Jekyll plugins (#230)
-
enhance test setup to allow multiple
_config.yml
files per fixture -
switch CI to GitHub Actions (#240)
-
implement
implicit_page_variables
asciidoc key support (#207) -
support Jekyll
unpublished
key overrriding AsciiDocpage-published
attribute (#257) -
Document the existing behavior around YAML page attributes and implement a way to merge config and page attributes for page variables. Merging requires a backwards incompatible change for object-valued page attributes from
_config.yml
; control this behavior with anenable_attribute_value_coercion
option (false by default). The existing behavior is now deprecated and will be removed in the next major version. (#158)
-
allow site-wide AsciiDoc attributes to also be defined on
asciidoc
key in site configuration (#126) -
set date page variable from revdate for any document in a collection (posts or otherwise) (#202)
-
allow non-ASCII word character to be used in name of attribute reference in config file
-
use File.write instead of IO.write (as IO.write has extra magic we don’t need)
-
auto-generate excerpts for posts and documents written in AsciiDoc (#200)
-
only support Ruby >= 2.2.0 and Jekyll >= 3.0.0
-
update tests to only run against supported versions
-
load processor eagerly (at end of plugin initialization)
-
don’t crash if document body is empty (#179)
-
process AsciiDoc header if page has only an AsciiDoc header but no body
-
honor layout defined in frontmatter defaults (#187)
-
allow page layout to be soft set in site config (#193)
-
set asciidoc property to true on all AsciiDoc pages (#189)
-
set asciidoc property to true on any (AsciiDoc) page enriched by this plugin (i.e., page.asciidoc) (#189)
-
don’t call nil_or_empty? outside of an Asciidoctor context (#142)
-
don’t delete category and tag; sync w/ first entry in array of matching property (#160)
-
don’t coerce a falsy value of page-layout defined in _config.yml to nil
-
integrate collections that are not written (output flag is set to false) (#161)
-
document how to enable STEM support (#163)
-
document that a liquid tag that includes HTML must be enclosed in a passthrough block (#180)
-
document that page attributes must be defined in the document header (#172)
-
document both the plugins and gems config keys and when to use one vs the other (#159)
-
document how to disable publishing for a page
-
document how to make a draft post
-
recommend installing gems into project and using a .ruby-version file
-
pass standalone option through data instead of prepending to content
-
set up code coverage reports (#196)
-
set up code linter (Rubocop) (#201)
-
honor layout defined in frontmatter defaults (#187)
-
don’t call nil_or_empty? outside of an Asciidoctor context (#142)
-
handle case when document body is empty (#179)
-
Add
tocify_asciidoc
Liquid filter for generating a table of contents from the parsed AsciiDoc document (Jekyll 3+ only) (#37) -
Remove trailing
@
when resolving attribute reference in value of attribute defined in config -
Set minimum version of Ruby to 1.9.3 in the gemspec
-
Prefixing attribute defined in config with minus removes previously defined (e.g., built-in) attribute (#123)
-
Convert attribute values in config as follows: true becomes empty string; false becomes nil, number becomes string (#127)
-
Merge category page variable into categories variable and tag page variable into tags variable (#149)
-
Assign document ID to page variable named docid (#146)
-
Enable CI for Windows platform by configuring job on AppVeyor
-
Catch SyntaxError when using Psych YAML parser with Ruby 1.9.3
-
Document that the name of page variable created from a page attribute is automatically lowercased
-
Parse the value of the revdate attribute using
Jekyll::Utils.parse_date
-
Document how to assign a specific time to a post
-
Document how to make site-wide AsciiDoc attributes accessible to Liquid templates (#137)
-
Fix crash when converting an auto-extracted excerpt when base_dir option is set to :docdir
-
Add additional documentation and make other minor improvements to the README
-
Align localtime and localdate attributes with site.time and site.timezone (#117)
-
Don’t register hook callbacks again when regenerating site; use static methods for hook callbacks (#121)
-
Bundle CHANGELOG.adoc and test suite in gem
-
Minor improvements to README
-
Split source into multiple files; move all classes under the
Jekyll::AsciiDoc
module -
Avoid redundant initialization caused by the jekyll-watch plugin
-
Set docdir, docfile, docname, outfile, outdir, and outpath attributes for each file (Jekyll 3+ only) (#59)
-
docdir is only set if value of
base_dir
option is:docdir
-
setting outdir allows proper integration with Asciidoctor Diagram
-
-
Automatically set
imagesoutdir
attribute ifimagesdir
attribute is relative to root -
Pass site information (root, source, destination, baseurl and url) through as AsciiDoc attributes
-
Automatically generate stylesheet for Pygments (#30)
-
Change default layout to match collection label (#104)
-
page for pages, post for posts, collection label for all others
-
use layout named default as fallback
-
-
Resolve attribute references in attribute values defined in config (#103)
-
Apply AsciiDoc header integration to documents in all collections (#93)
-
Document how to create and enable templates to customize the HTML that Asciidoctor generates (#73)
-
Allow
base_dir
option to track document directory by setting the value to:docdir
(Jekyll 3 only) (#80) -
Add a comprehensive test suite (#77)
-
Allow site-wide Asciidoctor attributes to be specified as a Hash; convert to Hash if Array is used (#87)
-
Interpret page attribute values as YAML data
-
Use Jekyll.logger to write log messages (#85)
-
Add topic to all log messages
-
Restructure configuration keys so all general settings are under the
asciidoc
key (#82) -
Don’t enable
hardbreaks
attribute by default (#69) -
Bump minimum version of Jekyll to 2.3.0 and document requirement in README (#76)
-
Allow layout to be disabled to create standalone document; add and document additional option values for layout (#63)
-
Make front matter header optional (#57)
-
Apply site-wide Asciidoctor configuration (options/attributes) when loading document header (#67)
-
Disable liquid processor on AsciiDoc files by default; enable using liquid page variable (#65)
-
Resolve empty page attribute value as empty string (#70)
-
Soft assign linkattrs attribute
-
Allow plugin to work in safe mode (#112)
-
Major restructure and rewrite of README
-
Document how to use plugin with GitLab Pages (#47)
-
Document
asciidocify
Liquid filter
-
Apply fix for documents that did not contain at least one attribute beginning with
page-
(#60)
-
The AsciiDoc document title overrides the title set in the front matter or the auto-generated title (in the case of a post) (#48)
-
The AsciiDoc page-related attributes override the matching entries in the page data (i.e., front matter)
-
The value of page-related attributes are treated as YAML values (automatic type coercion)
-
page-
is the default prefix for page-related AsciiDoc attributes (e.g.,page-layout
) (#51) -
The key to configure the page attribute prefix is
asciidoc_page_attribute_prefix
; the value should not contain the trailing hyphen (#51) -
The date of a post can be set using the
revdate
AsciiDoc attribute (#53) -
Only configure the Asciidoctor options once (previously it was being called twice in serve mode)
-
Set
env
attribute tosite
instead ofjekyll
(#55)
Enables use with Jekyll 3. It is still compatible with Jekyll 2.
-
Jekyll 3 support (#36, #33)
-
Documentation and onboarding improvements (#25, #24)
-
Improvements to release process (#28)
Initial release.