All notable changes to this project will be documented in this file. Updates should follow the Keep a CHANGELOG principles.
0.19.3 - 2019-06-18
- Fixed bug where elements with content of
"0"
wouldn't be rendered (#376)
0.19.2 - 2019-05-19
- Fixed bug where default values for nested configuration paths were inadvertently cast to strings
0.19.1 - 2019-04-10
- Added the missing
addExtension()
method to the newConfigurableEnvironmentInterface
- Fixed extensions not being able to register other extensions
0.19.0 - 2019-04-10
- The priority of parsers, processors, and renderers can now be set when
add()
ing them; you no longer need to rely on the order in which they are added - Added support for trying multiple parsers per block/inline
- Extracted two new base interfaces from
Environment
:EnvironmentInterface
ConfigurableEnvironmentInterface
- Extracted a new
AbstractStringContainerBlock
base class and correspondingStringContainerInterface
fromAbstractBlock
- Added
Cursor::getEncoding()
method - Added
.phpstorm.meta.php
file for better IDE code completion - Made some minor optimizations here and there
- Pretty much everything now has parameter and return types (#346)
- Attributes passed to
HtmlElement
will now be escaped by default Environment
is now afinal
classEnvironment::getBlockRendererForClass()
was replaced withEnvironment::getBlockRenderersForClass()
(note the addeds
)Environment::getInlineRendererForClass()
was replaced withEnvironment::getInlineRenderersForClass()
(note the addeds
)- The
Environment::get____()
methods now return an iterator instead of an array Context::addBlock()
no longer returns the same block instance you passed into the method, as this served no useful purposeRegexHelper::isEscapable()
no longer acceptsnull
valuesNode::replaceChildren()
now accepts any type ofiterable
, not justarray
s- Some block elements now extend
AbstractStringContainerBlock
instead ofAbstractBlock
InlineContainerInterface
now extends the newStringContainerInterface
- The
handleRemainingContents()
method (formerly onAbstractBlock
, now onAbstractStringContainerBlock
) is now an `abstract method - The
InlineParserContext
constructor now requires anAbstractStringContainerBlock
instead of anAbstractBlock
- Removed support for PHP 5.6 and 7.0 (#346)
- Removed support for
add()
ing parsers with just the target block/inline class name - you need to include the full namespace now - Removed the following unused methods from
Environment
:getInlineParser($name)
getInlineParsers()
createInlineParserEngine()
- Removed the unused
getName()
methods:AbstractBlockParser::getName()
AbstractInlineParser::getName()
BlockParserInterface::getName()
InlinerParserInterface::getName()
- Removed the now-useless classes:
AbstractBlockParser
AbstractInlinerParser
InlineContainer
- Removed the
AbstractBlock::acceptsLines()
method - Removed the now-useless constructor from
AbstractBlock
- Removed previously-deprecated functionality:
InlineContainer
classRegexHelper::$instance
RegexHelper::getInstance()
RegexHelper::getPartialRegex()
RegexHelper::getHtmlTagRegex()
RegexHelper::getLinkTitleRegex()
RegexHelper::getLinkDestinationBracesRegex()
RegexHelper::getThematicBreakRegex()
- Removed the second
$preserveEntities
parameter fromXml:escape()
0.18.5 - 2019-03-28
- Fixed the adjoining
Text
collapser not handling the full tree (thephpleague/commonmark-ext-autolink#10)
0.18.4 - 2019-03-23
- Modified how URL normalization decodes certain characters in order to align with the JS library's output
- Disallowed unescaped
(
in parenthesized link title
- Fixed two exponential backtracking issues
0.18.3 - 2019-03-21
This is a security update release.
- XML/HTML entities in attributes will no longer be preserved when rendering (#353)
- Fix XSS vulnerability caused by improper preservation of entities when rendering (#353)
- Deprecated the
$preserveEntites
argument ofXml::escape()
for removal in the next release (#353)
0.18.2 - 2019-03-16
- Fixed adjoining
Text
elements not being collapsed after delimiter processing
- Deprecated the
CommonmarkConverter::VERSION
constant for removal in 1.0.0
0.18.1 - 2018-12-29
This is a security update release.
- Fix XSS vulnerability caused by URL normalization not handling/encoding newlines properly (#337, CVE-2018-20583)
0.18.0 - 2018-09-18
- Added
ConverterInterface
toConverter
andCommonMarkConverter
(#330) - Added
ListItem::getListData()
method (#329)
- Links with
target="_blank"
will also getrel="noopener noreferrer"
by default (#331) - Implemented several performance optimizations (#324)
0.17.5 - 2018-03-29
- Fixed incorrect version constant value (again)
- Fixed release checklist to prevent the above from happening
- Fixed incorrect dates in CHANGELOG
0.17.4 - 2018-03-28
- Added
ListBlock::setTight()
method
0.17.3 - 2018-03-26
- Fixed incorrect version constant value
0.17.2 - 2018-03-25
- Added new
RegexHelper::isEscapable()
method
- Fixed spec compliance bug where escaped spaces should not be allowed in link destinations
0.17.1 - 2018-03-18
- Added a new constant containing the current version:
CommonMarkConverter::VERSION
(#314)
0.17.0 - 2017-12-30
This release contains several breaking changes and a minimum PHP version bump - see <UPGRADE.md> for more details.
- Added new
max_nesting_level
setting (#243) - Added minor performance optimizations to
Cursor
- Minimum PHP version is now 5.6.5.
- All full and partial regular expressions in
RegexHelper
are now defined as constants instead of being built on-the-fly. Cursor::saveState()
now returns anarray
instead of aCursorState
object.Cursor::restoreState()
now accepts anarray
parameter instead of aCursorState
object.- Saving/restoring the Cursor state no longer tracks things that don't change (like the text content).
RegexHelper
is nowfinal
.- References to
InlineContainer
changed to newInlineContainerInterface
interface. MiscExtension::addInlineParser()
andMiscExtension::addBlockRenderer()
now return$this
instead of nothing.
- Fixed
Reference::normalizeReference()
not properly collapsing whitespace to a single space
RegexHelper::getInstance()
and all instance (non-static) methods have been deprecated.- The
InlineContainer
interface has been deprecated. UseInlineContainerInterface
instead.
- Removed support for PHP 5.4 and 5.5.
- Removed
CursorState
class - Removed all previous deprecations:
Cursor::getFirstNonSpacePosition()
Cursor::getFirstNonSpaceCharacter()
Cursor::advanceWhileMatches()
Cursor::advanceToFirstNonSpace()
ElementRendererInterface::escape()
HtmlRenderer::escape()
RegexHelper::REGEX_UNICODE_WHITESPACE
RegexHelper::getLinkDestinationRegex()
0.16.0 - 2017-10-30
This release contains breaking changes, several performance improvements, and two deprecations:
- Added new
Xml
utility class; moved HTML/XML escaping logic into there (see deprecations below)
Environment::getInlineParsersForCharacter()
now returns an empty array (instead ofnull
) when no matching parsers are found- Three utility classes are now marked
final
:Html5Entities
LinkParserHelper
UrlEncoder
- Improved performance of several methods (for a 10% overall performance boost - #292)
The following methods were deprecated and are scheduled for removal in 0.17.0 or 1.0.0 (whichever comes first). See <UPGRADE.md> for more information.
Cursor::advanceWhileMatches()
deprecated; useCursor::match()
instead.HtmlRenderer::escape()
deprecated; useXml::escape()
instead.
- Removed
DelimiterStack::findFirstMatchingOpener()
which was previously deprecated in 0.15.0
0.15.7 - 2017-10-26
- Improved performance of
Cursor::advanceBy()
(for a 16% performance boost)
0.15.6 - 2017-08-08
- Fixed URI normalization not properly encoding/decoding special characters in certain cases (#287)
0.15.5 - 2017-08-05
This release bumps spec compliance to 0.28 without breaking changes to the API.
- Project is now tested against PHP 7.2
- Bumped CommonMark spec target to 0.28
- Changed internal implementation of
LinkParserHelper::parseLinkDestination()
to allow nested parens - Changed precedence of strong/emph when both nestings are possible (rule 14)
- Allow tabs before and after ATX closing header
- Fixed HTML type 6 block regex matching against
<pre>
(it shouldn't) and not matching<iframe>
(it should) - Fixed reference parser incorrectly handling escaped
]
characters - Fixed "multiple of 3" delimiter run calculations
An unused constant and static method were deprecated and will be removed in a future release. See <UPGRADE.md> for more information.
- Deprecated
RegexHelper::REGEX_UNICODE_WHITESPACE
(no longer used) - Deprecated
RegexHelper::getLinkDestinationRegex()
(no longer used)
0.15.4 - 2017-05-09
- Added new methods to
Cursor
(#280):advanceToNextNonSpaceOrNewline()
- Identical replacement for the (now-deprecated)advanceToFirstNonSpace()
methodadvanceToNextNonSpaceOrTab()
- Similar replacement foradvanceToFirstNonSpace()
but with proper tab handlinggetNextNonSpaceCharacter()
- Identical replacement for the (now-deprecated)getFirstNonSpaceCharacter()
methodgetNextNonSpacePosition()
- Identical replacement for the (now-deprecated)getFirstNonSpacePosition()
method
- Added new method to
CursorState
(#280):getNextNonSpaceCache()
- Identical replacement for the (now-deprecated)getFirstNonSpaceCache()
method
- Fixed duplicate characters in non-intended lines containing tabs (#279)
All deprecations listed here will be removed in a future 0.x release. See UPGRADE.md for instructions on preparing your code for the eventual removal of these methods.
- Deprecated
Cursor::advanceToFirstNonSpace()
(#280)- Use
advanceToNextNonSpaceOrTab()
oradvanceToNextNonSpaceOrNewline()
instead, depending on your requirements
- Use
- Deprecated
Cursor::getFirstNonSpaceCharacter()
(#280)- Use
Cursor::getNextNonSpaceCharacter()
instead
- Use
- Deprecated
Cursor::getFirstNonSpacePosition()
(#280)- Use
Cursor::getNextNonSpacePosition()
instead
- Use
- Deprecated
CursorState::getFirstNonSpaceCache()
(#280)- Use
CursorState::getNextNonSpaceCache()
instead
- Use
0.15.3 - 2016-12-18
- Allow inline parsers matching regex delimiter to be created (#271, #272)
0.15.2 - 2016-11-22
- Bumped spec target version to 0.27 (#268)
- H2-H6 elements are now parsed as HTML block elements instead of HTML inlines
- Fixed incomplete punctuation regex
- Fixed shortcut links not being allowed before a
(
- Fixed distinction between Unicode whitespace and regular whitespace
0.15.1 - 2016-11-08
- Fixed setext heading underlines not allowing trailing tabs (#266)
0.15.0 - 2016-09-14
- Added preliminary support for PHP 7.1 (#259)
- Added more regression tests (#258, #260)
- Bumped spec target version to 0.26 (#260)
- The
CursorState
constructor requires an additional parameter (#258) - Ordered lists cannot interupt a paragraph unless they start with
1
(#260) - Blank list items cannot interupt a paragraph (#260)
- Deprecated
DelimiterStack::findFirstMatchingOpener()
- usefindMatchingOpener()
instead (#260)
- Fixed tabs in ATX headers and thematic breaks (#260)
- Fixed issue where cursor state was not being restored properly (#258, #260)
- This fixed the lists-with-tabs regression reported in #258
- Removed an unnecessary check in
Cursor::advanceBy()
(#260) - Removed the two-blanks-break-out-of-lists feature (#260)
0.14.0 - 2016-07-02
- The
safe
option is deprecated and replaced by 2 new options (#253, #255):html_input
(strip
,allow
orescape
): how to handle untrusted HTML input (the default isstrip
for BC reasons)allow_unsafe_links
(true
orfalse
): whether to allow risky image URLs and links (the default istrue
for BC reasons)
- The
safe
option is now deprecated and will be removed in the 1.0.0 release.
0.13.4 - 2016-06-14
- Fixed path to
autoload.php
within bin/commonmark (#250)
0.13.3 - 2016-05-21
- Added
setUrl()
method forLink
andImage
elements (#227, #244) - Added cebe/markdown to the benchmark tool (#245)
0.13.2 - 2016-03-27
- Added ability to invoke
Converter
as a function (#233, #239) - Added new
advanceBySpaceOrTab
convenience method toCursor
- Bumped spec target version to 0.25
- Adjusted how tabs are handled by the
Cursor
(#234) - Made a couple small micro-optimizations to heavily used functions (#240)
- Updated URLs in docblocks to use HTTPS where possible (#238)
0.13.1 - 2016-03-09
- Refactored
EmphasisParser::parse()
to simplify it (#223) - Updated dev dependencies (#218 & #220)
- Fixed invalid regex generated when no inline parsers are defined (#224)
- Fixed logic bug with blank line after empty list item (#230)
- Fixed some incorrect code comments
- Removed unused variables (#223)
0.13.0 - 2016-01-13
- Added AST document processors (#210)
- Added optional
Environment
parameter toCommonMarkConverter
constructor
- Renamed "header" things to "heading" for spec consistency
Header
=>Heading
ATXHeaderParser
=>ATXHeadingParser
SetExtHeaderParser
=>SetExtHeadingParser
HeaderRenderer
=>HeadingRenderer
- Renamed "HorizontalRule" to "ThematicBreak" for spec consistency
HorizontalRule
=>ThematicBreak
HorizontalRuleParser
=>ThematicBreakParser
HorizontalRuleRenderer
=>ThematicBreakRenderer
HorizontalRuleRendererTest
=>ThematicBreakRendererTest
RegexHelper::getHRuleRegex()
=>RegexHelper::getThematicBreakRegex()
- Renamed inline "Html" and "RawHtml" to "HtmlInline" for consistency
Html
=>HtmlInline
RawHtmlParser
=>HtmlInlineParser
RawHtmlRenderer
=>HtmlInlineRenderer
- Don't allow whitespace between link text and link label of a reference link (spec change)
- Don't allow spaces in link destinations, even in
<>
- Allow multiline setext header content
- The
Heading
constructor now allows$contents
to be astring
(old behavior) orstring[]
(new)
- The
- Fixed several list issues and regressions (commonmark/commonmark.js#59)
- Removed schema whitelist from autolink regex
- Moved SmartPunct functionality into new league/commonmark-extras package
0.12.0 - 2015-11-04
- Added ability to configure characters and disable emphasis/strong (#135)
- Added new ConfigurationAwareInterface support for all parsers, processors, and renderers (#201)
- Added HTML safe mode to handle untrusted input (#200, #201)
- Safe mode is disabled by default for backwards-compatibility
- To enable it, set the
safe
option totrue
- Added AppVeyor integration for automated unit/functional testing on Windows (#195)
AbstractBlock::finalize()
now requires a second parameter,$endLineNumber
RegexHelper::REGEX_ENTITY
no longer includes the starting/
or the ending/i
(#194)Node::setParent()
now accepts null values (#203)
- Fixed incorrect
endLine
positions (#187) - Fixed
DocParser::preProcessInput
dropping up to 2 ending newlines instead of just one - Fixed
EntityParser
not checking for ampersands at the start of the current position (#192, #194)
- Removed protected function Context::addChild()
- It was a duplicate of the Context::addBlock() method
- Disabled STDIN reading on
bin/commonmark
for Windows due to PHP issues (#189, #195)
0.11.3 - 2015-09-25
- Reset container after closing containing lists (#183; commonmark/commonmark.js#67)
- The temporary fix from 0.11.2 was reverted
0.11.2 - 2015-09-23
- Fixed parser checking acceptsLines on the wrong element (#183)
0.11.1 - 2015-09-22
- Tightened up some loose comparisons
- Fixed missing "bin" directive in composer.json
- Updated a docblock to match recent changes to method parameters
- Removed unused variable from within QuoteProcessor's closure
0.11.0 - 2015-09-19
- Added new
Node
class, which bothAbstractBlock
andAbstractInline
extend from (#169) - Added a
NodeWalker
andNodeWalkerEvent
to traverse the AST without using recursion - Added new
InlineContainer
interface for blocks - Added new
getContainer()
andgetReferenceMap()
methods toInlineParserContext
- Added
iframe
to whitelist of HTML block tags (as per spec) - Added
./bin/commonmark
for converting Markdown at the command line
- Bumped spec target version to 0.22
- Revised AST to use a double-linked list (#169)
AbstractBlock
andAbstractInline
both extend fromNode
- Sub-classes must implement new
isContainer()
method
- Sub-classes must implement new
- Other major changes to
AbstractBlock
:getParent()
is nowparent()
setParent()
now expects aNode
instead of anAbstractBlock
getChildren()
is nowchildren()
getLastChild()
is nowlastChild()
addChild()
is nowappendChild()
InlineParserContext
is constructed using the containerAbstractBlock
and the document'sRefereceMap
- The constructor will automatically create the
Cursor
using the container's string contents
- The constructor will automatically create the
InlineParserEngine::parse
now requires theNode
container and the document'sReferenceMap
instead of aContextInterface
andCursor
- Changed
Delimiter
to reference the actual inlineNode
instead of the position- The
int $pos
protected member and constructor arg is nowNode $node
- Use
getInlineNode()
andsetInlineNode()
instead ofgetPos()
andsetPos()
- The
- Changed
DocParser::processInlines
to use aNodeWalker
to iterate through inlines- Walker passed as second argument instead of
AbstractBlock
- Uses a
while
loop instead of recursion to traverse the AST
- Walker passed as second argument instead of
Image
andLink
now only accept a string as their second argument- Refactored how
CloseBracketParser::parse()
works internally CloseBracketParser::createInline
no longer accepts label inlines- Disallow list item starting with multiple blank lines (see commonmark/commonmark-spec#332)
- Modified
AbstractBlock::setLastLineBlank()
- Functionality moved to
AbstractBlock::shouldLastLineBeBlank()
and newDocParser::setAndPropagateLastLineBlank()
method AbstractBlock::setLastLineBlank()
is now a setter method forAbstractBlock::$lastLineBlank
- Functionality moved to
AbstractBlock::handleRemainingContents()
is no longer abstract- A default implementation is provided
- Removed duplicate code from sub-classes which used the default implementation - they'll just use the parent method from now on
- Fixed logic error in calculation of offset (see jgm/commonmark.js@94053a8)
- Fixed bug where
DocParser
checked the wrong method to determine remainder handling behavior - Fixed bug where
HorizontalRuleParser
failed to advance the cursor beyond the parsed horizontal rule characters - Fixed
DocParser
not ignoring the final newline of the input (like the reference parser does)
- Removed
Block\Element\AbstractInlineContainer
- Extend
AbstractBlock
and implementInlineContainer
instead - Use child methods instead of
getInlines
andsetInlines
- Extend
- Removed
AbstractBlock::replaceChild()
- Call
Node::replaceWith()
directly the child node instead
- Call
- Removed the
getInlines()
method fromInlineParserContext
- Add parsed inlines using
$inlineContext->getContainer()->appendChild()
instead of$inlineContext->getInlines()->add()
- Add parsed inlines using
- Removed the
ContextInterface
argument fromAbstractInlineParser::parse()
andInlineParserEngine::parseCharacter
- Removed the first
ArrayCollection $inlines
argument fromInlineProcessorInterface::processInlines()
- Removed
CloseBracketParser::nullify()
- Removed
pre
from rule 6 of HTML blocks (see commonmark/commonmark-spec#355)
0.10.0 - 2015-07-25
- Added parent references to inline elements (#124)
- Added smart punctuation extension (#134)
- Added HTML block types
- Added indentation caching to the cursor
- Added automated code style checks (#133)
- Added support for tag attributes in renderers (#101, #165)
- Bumped spec target version to 0.21
- Revised HTML block parsing to conform to new spec (jgm/commonmark.js@99bd473)
- Imposed 9-digit limit on ordered list markers, per spec
- Allow non-initial hyphens in html tag names (commonmark/commonmark-spec#239)
- Updated list of block tag names
- Changed tab/indentation handling to meet the new spec behavior
- Modified spec tests to show spaces and tabs in test results
- Replaced
HtmlRendererInterface
withElementRendererInterface
(#141) - Removed the unnecessary
trim()
and string cast fromListItemRenderer
- Fixed link reference definition edge case (#120)
- Allow literal (non-escaping) backslashes in link destinations (#118)
- Allow backslash-escaped backslashes in link labels (#119)
- Allow link labels up to 999 characters (per the spec)
- Properly split on whitespace when determining code block class (commonmark/commonmark.js#54)
- Fixed code style issues (#132, #133, #151, #152)
- Fixed wording for invalid inline exception (#136)
- Removed the advance-by-one optimization due to added cursor complexity
0.9.0 - 2015-06-18
- Added public $data array to block elements (#95)
- Added
isIndented
helper method toCursor
- Added a new
Converter
base class whichCommonMarkConverter
extends from (#105)
- Bumped spec target version to 0.20 (#112)
- Renamed ListBlock::$data and ListItem::$data to $listData
- Require link labels to contain non-whitespace (commonmark/commonmark-spec#322)
- Use U+FFFD for entities resolving to 0 (commonmark/commonmark-spec#323)
- Moved
IndentedCodeParser::CODE_INDENT_LEVEL
toCursor::INDENT_LEVEL
- Changed arrays to short syntax (#116)
- Improved efficiency of DelimiterStack iteration (commonmark/commonmark.js#43)
- Fixed open block tag followed by newline not being recognized (commonmark/commonmark-spec#324)
- Fixed indented lists sometimes being parsed incorrectly (commonmark/commonmark.js#42)
0.8.0 - 2015-04-29
- Allow swapping built-in renderers without using their fully qualified names (#84)
- Lots of unit tests (for existing code)
- Ability to include arbitrary functional tests in addition to spec-based tests
- Dropped support for PHP 5.3 (#64 and #76)
- Bumped spec target version to 0.19
- Made the AbstractInlineContainer be abstract
- Moved environment config. logic into separate class
- Fixed underscore emphasis to conform to spec changes (commonmark/commonmark-spec#317)
- Removed PHP 5.3 workaround (see commit 5747822)
- Removed unused AbstractWebResource::setUrl() method
- Removed unnecessary check for hrule when parsing lists (#85)
0.7.2 - 2015-03-08
- Bumped spec target version to 0.18
- Fixed broken parsing of emphasized text ending with a '0' character (#81)
0.7.1 - 2015-03-01
- All references can now be obtained from the
ReferenceMap
vialistReferences()
(#73) - Test against PHP 7.0 (nightly) but allow failures
- ListData::$start now defaults to null instead of 0 (#74)
- Replace references to HtmlRenderer with new HtmlRendererInterface
- Fixed 0-based ordered lists starting at 1 instead of 0 (#74)
- Fixed errors parsing multi-byte characters (#78 and #79)
0.7.0 - 2015-02-16
- More unit tests to increase code coverage
- Enabled the InlineParserEngine to parse several non-special characters at once (performance boost)
- NewlineParser no longer attempts to parse spaces; look-behind is used instead (major performance boost)
- Moved closeUnmatchedBlocks into its own class
- Image and link elements now extend AbstractInlineContainer; label data is stored via $inlineContents instead
- Renamed AbstractInlineContainer::$inlineContents and its getter/setter
- Removed the InlineCollection class
- Removed the unused ArrayCollection::splice() method
- Removed impossible-to-reach code in Cursor::advanceToFirstNonSpace
- Removed unnecessary test from the InlineParserEngine
- Removed unnecessary/unused RegexHelper::getMainRegex() method
0.6.1 - 2015-01-25
- Bumped spec target version to 0.17
- Updated emphasis parsing for underscores to prevent intra-word emphasis
- Deferred closing of fenced code blocks
0.6.0 - 2015-01-09
- Bulk registration of parsers/renderers via extensions (#45)
- Proper UTF-8 support, especially in the Cursor; mbstring extension is now required (#49)
- Environment is now configurable; options can be accessed in its parsers/renderers (#56)
- Added some unit tests
- Bumped spec target version to 0.15 (#50)
- Parsers/renderers are now lazy-initialized (#52)
- Some private elements are now protected for easier extending, especially on Element classes (#53)
- Renderer option keys changed from camelCase to underscore_case (#56)
- Moved CommonMark parser/render definitions into CommonMarkCoreExtension
- Improved parsing of emphasis around punctuation
- Improved regexes for CDATA and HTML comments
- Fixed issue with HTML content that is considered false in loose comparisons, like
'0'
(#55) - Fixed DocParser trying to add empty strings to closed containers (#58)
- Fixed incorrect use of a null parameter value in the HtmlElementTest
- Removed unused ReferenceDefinition* classes (#51)
- Removed UnicodeCaseFolder in favor of mb_strtoupper
0.5.1 - 2014-12-27
- Fixed infinite loop and link-in-link-in-image parsing (#37)
- Removed hard dependency on mbstring extension; workaround used if not installed (#38)
0.5.0 - 2014-12-24
- Support for custom directives, parsers, and renderers
- Major refactoring to de-couple directives from the parser, support custom directive functionality, and reduce complexity
- Updated references to stmd.js in README and docblocks
- Modified CHANGELOG formatting
- Improved travis configuration
- Put tests in autoload-dev
- Fixed CommonMarkConverter re-creating object each time new text is converted (#26)
- Removed HtmlRenderer::render() (use the renderBlock method instead)
- Removed dependency on symfony/options-resolver (fixes #20)
0.4.0 - 2014-12-15
- Added some missing copyright info
- Changed namespace to League\CommonMark
- Made compatible with spec version 0.13
- Moved delimiter stack functionality into separate class
- Fixed regex which caused HHVM tests to fail
0.3.0 - 2014-11-28
- Made renderer options configurable (issue #7)
- Made compatible with spec version 0.12
- Stack-based parsing now used for emphasis, links and images
- Protected some of the internal renderer methods which shouldn't have been
public
- Minor code clean-up (including PSR-2 compliance)
- Removed unnecessary distinction between ATX and Setext headers
0.2.1 - 2014-11-09
- Added simpler string replacement to a method
- Removed "is" prefix from boolean methods
- Updated to latest version of PHPUnit
- Target specific spec version
0.2.0 - 2014-11-09
- Mirrored significant changes and improvements from stmd.js
- Made compatible with spec version 0.10
- Updated location of JGM's repository
- Allowed HHVM tests to fail without affecting overall build success
- Removed composer.lock
- Removed fixed reference to jgm/stmd@0275f34
0.1.2 - 2014-09-28
- Added performance benchmarking tool (issue #2)
- Added more badges to the README
- Fix JS -> PHP null judgement (issue #4)
- Updated phpunit dependency
0.1.1 - 2014-09-08
- Add anchors to regexes
- Updated target spec (now compatible with jgm/stmd:spec.txt @ 2cf0750)
- Adjust HTML output for fenced code
- Adjust block-level tag regex (remove "br", add "iframe")
- Fix incorrect handling of nested emphasis
- Initial commit (compatible with jgm/stmd:spec.txt @ 0275f34)