Update org.jsoup:jsoup
to v1.18.3
(was 1.17.2
)
#798
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
1.17.2
->1.18.3
Release Notes
jhy/jsoup (org.jsoup:jsoup)
v1.18.3
Bug Fixes
-
,.
, or digits were incorrectly marked as invalid andremoved. 2235
;
in an attribute name, it could not be converted to a W3C DOM element, and so subsquent XPathqueries could miss that element. Now, the attribute name is more completely
normalized. 2244
v1.18.2
Improvements
down between -6% and -89%, and throughput improved up to +143% for small inputs. Most inputs sizes will see
throughput increases of ~ 20%. These performance improvements come through recycling the backing
byte[]
andchar[]
arrays used to read and parse the input. 2186
html()
andEntities.escape()
when the input contains UTF characters in a supplementary plane, byaround 49%. 2183
FormElement.elements()
now reflect changes made to the DOM,subsequently to the original parse. 2140
TreeBuilder
, theonNodeInserted()
andonNodeClosed()
events are now also fired for the outermost /root
Document
node. This enables source position tracking on the Document node (which was previously unset). Andit also enables the node traversor to see the outer Document node. 2182
Elements#set()
. 2212Bug Fixes
Element.cssSelector()
would fail if the element's class contained a*
character. 2169
untracked. 2175
html
, it should be parsed in QuirksMode. 2197
div:has(span + a)
, thehas()
component was not working correctly, as the inner combiningquery caused the evaluator to match those against the outer's siblings, not
children. 2187
:has()
components in a nested:has()
might incorrectlyexecute. 2131
Connection.Response#cookies()
will provide the last one set. Generally it is better to usethe Jsoup.newSession method to maintain a cookie jar, as that
applies appropriate path selection on cookies when making requests. 1831
attribute). 2207
created (
html
orbody
). 2204<
as part of a tag name, instead of emitting it as acharacter node. 2230
<
as the start of an attribute name, vs creating a new element. The previous behavior wasintended to parse closer to what we anticipated the author's intent to be, but that does not align to the spec or to
how browsers behave. 1483
v1.18.1
Improvements
StreamParser
provides a progressive parse of its input. As eachElement
is completed, it isemitted via a
Stream
orIterator
interface. Elements returned will be complete with all their children, and an(empty) next sibling, if applicable. Elements (or their children) may be removed from the DOM during the parse,
for e.g. to conserve memory, providing a mechanism to parse an input document that would otherwise be too large to fit
into memory, yet still providing a DOM interface to the document and its elements. Additionally, the parser provides
a
selectFirst(String query)
/selectNext(String query)
, which will run the parser until a hit is found, at whichpoint the parse is suspended. It can be resumed via another
select()
call, or via thestream()
oriterator()
methods. 2096
parsed). Supported on both a session and a single connection
level. 2164, 656
Path
accepting parse methods:Jsoup.parse(Path)
,Jsoup.parse(path, charsetName, baseUri, parser)
,etc. 2055
button
tag configuration to include a space between multiple button elements in theElement.text()
method. 2105
ns|*
all elements in namespace Selector. 1811_
, vs beingstripped. This should make the process clearer, and generally prevent an invalid attribute name being coerced
unexpectedly. 2143
Changes
Bug Fixes
to
-1.
2106{
,}
in the path, a Malformed URL exception wouldbe thrown (if in development), or the URL might otherwise not be escaped correctly (if in
production). The URL encoding process has been improved to handle these characters
correctly. 2142
W3CDom
with a custom output Document, a Null Pointer Exception would bethrown. 2114
:has()
selector did not match correctly when using sibling combinators (likee.g.:
h1:has(+h2)
). 2137:empty
selector incorrectly matched elements that started with a blank text node and were followed bynon-empty nodes, due to an incorrect short-circuit. 2130
Element.cssSelector()
would fail with "Did not find balanced marker" when building a selector for elements that hada
(
or[
in their class names. And selectors with those characters escaped would not match asexpected. 2146
Entities.escape(string)
to make the escaped text suitable for both text nodes and attributes (previously wasonly for text nodes). This does not impact the output of
Element.html()
which correctly applies a minimal escapedepending on if the use will be for text data or in a quoted
attribute. 1278
<base href>
URL, in the normalizing regex.2165
Configuration
📅 Schedule: Branch creation - "monthly" (UTC), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR was generated by Mend Renovate. View the repository job log.