Releases: thephpleague/commonmark
Releases · thephpleague/commonmark
2.0.0-rc2
1.6.6
2.0.0-rc1
No changes were introduced since the previous release.
2.0.0-beta3
Changed
- Any leading UTF-8 BOM will be stripped from the input
- The
getEnvironment()method ofCommonMarkConverterandGithubFlavoredMarkdownConverterwill always return the concrete, configurableEnvironmentfor upgrading convenience - Optimized AST iteration
- Lots of small micro-optimizations
2.0.0-beta2
See https://commonmark.thephpleague.com/2.0/upgrading/ for detailed information on upgrading to version 2.0.
Added
Changed
- Made compatible with CommonMark spec 0.30.0
- Optimized link label parsing
- Optimized AST iteration for a 50% performance boost in some event listeners (#683, #684)
Fixed
- Fixed processing instructions with EOLs
- Fixed case-insensitive matching for HTML tag types
- Fixed type 7 HTML blocks incorrectly interrupting lazy paragraphs
- Fixed newlines in reference labels not collapsing into spaces
- Fixed link label normalization with escaped newlines
- Fixed unnecessary AST iteration when no default attributes are configured
1.6.5
2.0.0-beta1
See https://commonmark.thephpleague.com/2.0/upgrading/ for detailed information on upgrading to version 2.0.
Added
- Added three new extensions:
FrontMatterExtension(see documentation)DescriptionListExtension(see documentation)DefaultAttributesExtension(see documentation)
- Added new
XmlRendererto simplify AST debugging (see documentation) (#431) - Added the ability to configure disallowed raw HTML tags (#507)
- Added the ability for Mentions to use multiple characters for their symbol (#514, #550)
- Added the ability to delegate event dispatching to PSR-14 compliant event dispatcher libraries
- Added new configuration options:
- Added
heading_permalink/min_heading_levelandheading_permalink/max_heading_leveloptions to control which headings get permalinks (#519) - Added
heading_permalink/fragment_prefixto allow customizing the URL fragment prefix (#602) - Added
footnote/backref_symboloption for customizing backreference link appearance (#522) - Added
slug_normalizer/max_lengthoption to control the maximum length of generated URL slugs - Added
slug_normalizer/uniqueoption to control whether unique slugs should be generated per-document or per-environment
- Added
- Added purity markers throughout the codebase (verified with Psalm)
- Added
Queryclass to simplify Node traversal when looking to take action on certain Nodes - Added new
HtmlFilterandStringContainerHelperutility classes - Added new
AbstractBlockContinueParserclass to simplify the creation of custom block parsers - Added several new classes and interfaces:
BlockContinueBlockContinueParserInterfaceBlockContinueParserWithInlinesInterfaceBlockStartBlockStartParserInterfaceChildNodeRendererInterfaceConfigurableExtensionInterfaceCursorStateDashParser(extracted fromPunctuationParser)DelimiterParserDocumentBlockParserDocumentPreRenderEventDocumentRenderedEventEllipsesParser(extracted fromPunctuationParser)ExpressionInterfaceFallbackNodeXmlRendererInlineParserEngineInterfaceInlineParserMatchMarkdownParserStateMarkdownParserStateInterfaceMarkdownRendererInterfaceQueryRawMarkupContainerInterfaceReferenceableInterfaceRenderedContentRenderedContentInterfaceReplaceUnpairedQuotesListenerSpecReaderTableOfContentsRendererUniqueSlugNormalizerUniqueSlugNormalizerInterfaceXmlRendererXmlNodeRendererInterface
- Added several new methods:
Cursor::getCurrentCharacter()Environment::createDefaultConfiguration()Environment::setEventDispatcher()EnvironmentInterface::getExtensions()EnvironmentInterface::getInlineParsers()EnvironmentInterface::getSlugNormalizer()FencedCode::setInfo()Heading::setLevel()HtmlRenderer::renderDocument()InlineParserContext::getFullMatch()InlineParserContext::getFullMatchLength()InlineParserContext::getMatches()InlineParserContext::getSubMatches()LinkParserHelper::parsePartialLinkLabel()LinkParserHelper::parsePartialLinkTitle()Node::assertInstanceOf()RegexHelper::isLetter()StringContainerInterface::setLiteral()TableCell::getType()TableCell::setType()TableCell::getAlign()TableCell::setAlign()
Changed
- Changed the converter return type
CommonMarkConverter::convertToHtml()now returns an instance ofRenderedContentInterface. This can be cast to a string for backward compatibility with 1.x.
- Table of Contents items are no longer wrapped with
<p>tags (#613) - Heading Permalinks now link to element IDs instead of using
nameattributes (#602) - Heading Permalink IDs and URL fragments now have a
contentprefix by default (#602) - Changes to configuration options:
enable_emhas been renamed tocommonmark/enable_emenable_stronghas been renamed tocommonmark/enable_stronguse_asteriskhas been renamed tocommonmark/use_asteriskuse_underscorehas been renamed tocommonmark/use_underscoreunordered_list_markershas been renamed tocommonmark/unordered_list_markersmentions/*/symbolhas been renamed tomentions/*/prefixmentions/*/regexhas been renamed tomentions/*/patternand requires partial regular expressions (without delimiters or flags)max_nesting_levelnow defaults toPHP_INT_MAXand no longer supports floatsheading_permalink/slug_normalizerhas been renamed toslug_normalizer/instance
- Event dispatching is now fully PSR-14 compliant
- Moved and renamed several classes - see the full list here
- The
HeadingPermalinkExtensionandFootnoteExtensionwere modified to ensure they never produce a slug which conflicts with slugs created by the other extension SlugNormalizer::normalizer()now supports optional prefixes and max length options passed in via the$contextargument- The
AbstractBlock::$dataandAbstractInline::$dataarrays were replaced with aDataarray-like object on the baseNodeclass - Implemented a new approach to block parsing. This was a massive change, so here are the highlights:
- Functionality previously found in block parsers and node elements has moved to block parser factories and block parsers, respectively (more details)
ConfigurableEnvironmentInterface::addBlockParser()is nowEnvironmentBuilderInterface::addBlockParserFactory()ReferenceParserwas re-implemented and works completely different than before- The paragraph parser no longer needs to be added manually to the environment
- Implemented a new approach to inline parsing where parsers can now specify longer strings or regular expressions they want to parse (instead of just single characters):
InlineParserInterface::getCharacters()is nowgetMatchDefinition()and returns an instance ofInlineParserMatchInlineParserContext::__construct()now requires the contents to be provided as aCursorinstead of astring
- Implemented delimiter parsing as a special type of inline parser (via the new
DelimiterParserclass) - Changed block and inline rendering to use common methods and interfaces
BlockRendererInterfaceandInlineRendererInterfacewere replaced byNodeRendererInterfacewith slightly different parameters. All core renderers now implement this interface.ConfigurableEnvironmentInterface::addBlockRenderer()andaddInlineRenderer()were combined intoEnvironmentBuilderInterface::addRenderer()EnvironmentInterface::getBlockRenderersForClass()andgetInlineRenderersForClass()are now justgetRenderersForClass()
- Completely refactored the Configuration implementation
- All configuration-specific classes have been moved into a new
league/configpackage with a new namespace Configurationobjects must now be configured with a schema and all options must match that schema - arbitrary keys are no longer permittedConfiguration::__construct()no longer accepts the default configuration values - useConfiguration::merge()insteadConfigurationInterfacenow only contains aget(string $key); this method no longer allows arbitrary default values to be returned if the option is missingConfigurableEnvironmentInterfacewas renamed toEnvironmentBuilderInterfaceExtensionInterface::register()now requires anEnvironmentBuilderInterfaceparam instead ofConfigurableEnvironmentInterface
- All configuration-specific classes have been moved into a new
- Added missing return types to virtually every class and interface method
- Re-implemented the GFM Autolink extension using the new inline parser approach instead of document processors
EmailAutolinkProcessoris nowEmailAutolinkParserUrlAutolinkProcessoris nowUrlAutolinkParser
HtmlElementcan now properly handle array (i.e.class) and boolean (i.e.checked) attribute valuesHtmlElementautomatically flattens any attributes with array values into space-separated strings, removing duplicate entries- Combined separate classes/interfaces into one:
DisallowedRawHtmlRendererreplacesDisallowedRawHtmlBlockRendererandDisallowedRawHtmlInlineRendererNodeRendererInterfacereplacesBlockRendererInterfaceandInlineRendererInterface
- Renamed the following methods:
EnvironmentandConfigurableEnvironmentInterface:addBlockParser()is nowaddBlockStartParser()
ReferenceMapandReferenceMapInterface:addReference()is nowadd()getReference()is nowget()listReferences()is nowgetIterator()
- Various node (block/inline) classes:
getContent()is nowgetLiteral()setContent()is nowsetLiteral()
- Moved and renamed the following constants:
EnvironmentInterface::HTML_INPUT_ALLOWis nowHtmlFilter::ALLOWEnvironmentInterface::HTML_INPUT_ESCAPEis nowHtmlFilter::ESCAPEEnvironmentInterface::HTML_INPUT_STRIPis nowHtmlFilter::STRIPTableCell::TYPE_HEADis nowTableCell::TYPE_HEADERTableCell::TYPE_BODYi...
1.6.4
Changed
- Optimized attribute parsing to avoid inspecting every space character (30% performance boost)
1.6.3
1.6.2
Fixed
- Fixed incorrect error level for deprecation notices