Nick Wellnhofer
a2b5c90a44
hash: Fix deletion of entries during scan
...
Functions like xmlCleanSpecialAttr scan a hash table and possibly delete
entries in the callback. xmlHashScanFull must detect such deletions and
rescan the entry.
This regressed when rewriting the hash table code in 4a513d56.
Fixes #626 .
2023-11-21 15:28:59 +01:00
Nick Wellnhofer
aca37d8c77
parser: Only enable SAX2 if there are SAX2 element handlers
...
This reverts part of commit 235b15a5 for backward compatibility and
adds some comments trying to clarify the whole mess.
Fixes #623 .
2023-11-20 15:20:37 +01:00
Nick Wellnhofer
272cb22313
dict: Fix '__thread' before 'static'
...
When used with extern or static, __thread must appear immediately after
the other storage class specifier.
Fixes #621 .
2023-11-20 14:24:13 +01:00
Mike Dalessio
62d318f86c
fix: more pthread weak references in globals.c
2023-11-18 15:37:26 -05:00
Mike Dalessio
1ac88300c1
fix: pthread weak references in globals.c
...
Linking executables will fail on systems with glibc < 2.34 without
declaring these symbols as weak references.
In commit c19771c1f13de9196f98260d142d8c8672eb5733 these references
were moved to globals.c from threads.c, but the `#pragma weak`
declarations were lost in the process.
Also removing unneeded weak declarations from threads.c.
2023-11-18 18:26:48 +00:00
Nick Wellnhofer
f92ea2ccec
tests: Fix build with older MSVC
...
Regressed in 9b5cce7a.
Fixes #620 .
2023-11-18 14:36:41 +01:00
Nick Wellnhofer
3669316ad1
Bump version
2023-11-16 13:34:03 +01:00
Nick Wellnhofer
5e9b167dce
Release v2.12.0
v2.12.0
2023-11-16 13:20:16 +01:00
Nick Wellnhofer
529df19619
parser: Don't overwrite error state in xmlParseTextDecl
...
Fixes a null deref in xmlLoadEntityContent found by OSS-Fuzz.
2023-11-15 12:11:33 +01:00
Nick Wellnhofer
da703eaaea
schemas: Fix reallocation in xmlSchemaXPathProcessHistory
...
See #614 .
2023-11-05 02:03:05 +01:00
Nick Wellnhofer
70cc45b81f
parser: Improve attribute hash table
...
There's no need to grow the hash table dynamically. The size is known
which simplifies the implementation.
2023-11-05 00:49:40 +01:00
Nick Wellnhofer
5859849454
parser: Fix combination of hash values
...
This bug resulted in a stuck bit in hash values which can have a severe
performance impact.
2023-11-04 23:50:02 +01:00
Nick Wellnhofer
a31e1b0665
SAX2: Fix quadratic behavior in xmlSAX2AttributeNs
...
The last missing piece to make parsing of attributes O(n).
2023-11-04 20:21:54 +01:00
Nick Wellnhofer
a40c32ac1f
doc: Regenerate documentation
2023-11-04 19:32:48 +01:00
Nick Wellnhofer
c682089421
tests: Regenerate testapi.c
2023-11-04 19:32:48 +01:00
Nick Wellnhofer
a7b037952f
doc: Minor fixes for apibuild.py
2023-11-04 19:32:48 +01:00
Nick Wellnhofer
56944c517f
python: Make sure to distribute new files
...
Add pyproject.toml and tests/setup_test.py to Makefile.am.
2023-11-04 19:32:07 +01:00
Nick Wellnhofer
7a2d412f68
parser: Copy default namespace in xmlParseBalancedChunkMemory
2023-10-31 20:19:27 +01:00
Nick Wellnhofer
e0c2f14d83
parser: Copy namespaces in xmlParseBalancedChunkMemory
...
Reenable copying of namespaces but don't set SAX data. This should
match the old behavior.
2023-10-31 14:04:57 +01:00
Nick Wellnhofer
89d19534de
encoding: Fix decoding of large chunks
...
After 95e81a36, we must support XML_ENC_ERR_SPACE when using built-in
encoding handlers.
Should fix #610 .
2023-10-28 03:14:13 +02:00
Nick Wellnhofer
0c18af8306
Update NEWS
2023-10-24 17:45:41 +02:00
Nick Wellnhofer
61034116d0
error: Make more xmlError structs constant
...
Prepare for future changes, see 45470611.
2023-10-24 15:02:36 +02:00
Daniel Garcia Moreno
6f78efb0fa
python: Make it compatible with python3.12
...
Python 3.12 removes distutils so it's mandatory to use setuptools with
python >= 3.12.
This patch prints a message when trying to run the setup.py script with
a python >= 3.12 without setuptools and try to use the setuptools import
by default.
This patch also creates a new file, pyproject.toml [1], to prepare for
building in modern systems.
[1] https://peps.python.org/pep-0517/
2023-10-23 18:02:03 +02:00
Nick Wellnhofer
5221fcd42d
tests: Also test xmlNextChar in testchar.c
2023-10-22 16:32:54 +02:00
Nick Wellnhofer
028566745c
parser: Remove redundant IS_CHAR check in xmlCurrentChar
2023-10-22 16:32:54 +02:00
Nick Wellnhofer
c082ef4644
parser: Stop switching to ISO-8859-1 on encoding errors
...
Use U+FFFD Replacement Character if invalid UTF-8 is encountered in
recovery mode.
Also rewrite xmlNextChar and xmlCurrentChar.
Fixes #598 .
2023-10-22 16:32:54 +02:00
Nick Wellnhofer
a9ada18352
tests: Start with testparser.c for extra tests
...
Several issues require customized tests. Start with a test that push
parses large documents. See #539 .
2023-10-22 14:24:43 +02:00
Nick Wellnhofer
572ecc1719
parser: Fix buffer shrinking when push parsing
...
Short-lived regression from b76d81da.
2023-10-22 14:01:50 +02:00
Nick Wellnhofer
253f260bb1
threads: Fix --with-thread-alloc
...
Fixes #606 .
2023-10-18 20:07:04 +02:00
Nick Wellnhofer
4f132bcdb3
fuzz: Raise rss_limit_mb
2023-10-15 13:04:54 +02:00
Nick Wellnhofer
c13a019134
fuzz: Test xmlTextReaderRead after EOF or failure
2023-10-15 13:04:54 +02:00
Nick Wellnhofer
e019d97fd0
fuzz: Test XML_PARSE_XINCLUDE | XML_PARSE_VALID
2023-10-15 13:04:54 +02:00
Nick Wellnhofer
86ef190e53
parser: Fix stack handling in xmlParseTryOrFinish
...
After commit e0dd330b, this latent bug could cause use-after-free errors
in rare circumstances like using the reader API with recovery and
XIncludes.
2023-10-14 22:57:58 +02:00
Nick Wellnhofer
7dfcea03c3
dict: Fix integer overflow in xmlDictAddString
...
Short-lived regression.
Older versions didn't check for integer overflow, but limited name
length to INT_MAX / 2. Reintroduce this limit.
Found by OSS-Fuzz.
2023-10-11 18:02:23 +02:00
Nick Wellnhofer
fef12ed816
buf: Also reset input in error case
...
Avoid dangling pointers if memory allocation failed. This could cause
a use-after-free after recent changes.
Found by OSS-Fuzz.
2023-10-11 13:32:54 +02:00
Nick Wellnhofer
514ab39955
parser: Don't overwrite error state in xmlParseTextDecl
...
If a memory allocation fails, this could cause a null deref after
recent changes.
Found by OSS-Fuzz.
2023-10-11 13:27:44 +02:00
Nick Wellnhofer
821a037038
parser: Fix memory leak in xmlLoadEntityContent
...
Found by OSS-Fuzz.
2023-10-09 15:20:00 +02:00
Nick Wellnhofer
4fc5340ec5
parser: Also grow comment buffer if SAX is disabled
...
Fix short-lived regression from 8afd321a, found by OSS-Fuzz.
2023-10-08 14:26:35 +02:00
Nick Wellnhofer
36374bc9fc
parser: Fix error handling in xmlLoadEntityContent
...
Backup more members of context struct. Fix small accounting error.
2023-10-08 14:08:44 +02:00
Nick Wellnhofer
b76d81dab3
parser: Fix regression when push parsing parameter entities
...
Short-lived regression from 834b8123.
Also shrink parameter entity buffers when push parsing.
2023-10-06 13:11:19 +02:00
Nick Wellnhofer
134d2ad890
parser: Protect against quadratic default attribute expansion
2023-10-06 12:47:24 +02:00
Nick Wellnhofer
7615fae62e
parser: Make XML_PARSE_NSCLEAN option work again
2023-10-06 12:28:59 +02:00
Nick Wellnhofer
0ba22c0513
parser: Support encoded external PEs in entity values
...
Corner case which was never supported.
2023-10-06 12:28:59 +02:00
Nick Wellnhofer
8afd321abd
parser: Missing checks for disableSAX
2023-10-06 12:28:59 +02:00
Nick Wellnhofer
6337a14a6b
tests: Handle entities in SAX tests
2023-10-06 12:28:59 +02:00
Nick Wellnhofer
713ded60ad
entities: Make xmlFreeEntity public
2023-10-06 10:47:07 +02:00
Nick Wellnhofer
97e99f4112
parser: Acknowledge that entities with namespaces are broken
...
Entities which reference out-of-scope namespace have always been broken.
xmlParseBalancedChunkMemoryInternal tried to reuse the namespaces
currently in scope but these namespaces were ignored by the SAX handler.
Besides, there could be different namespaces in scope when expanding the
entity again. For example:
<!DOCTYPE doc [
<!ENTITY ent "<ns:elem/>">
]>
<doc>
<decl1 xmlns:ns="urn:ns1">
&ent;
</decl1>
<decl2 xmlns:ns="urn:ns2">
&ent;
</decl2>
</doc>
Add some comments outlining possible solutions to this problem.
For now, we stop copying namespaces to the temporary parser context
in xmlParseBalancedChunkMemoryInternal. This has never really worked
and the recent changes contained a partial fix which uncovered other
problems like a use-after-free with the XML Reader interface, found
by OSS-Fuzz.
2023-10-05 17:41:46 +02:00
Nick Wellnhofer
b8e03e13ed
examples: Don't use sprintf
...
Avoids warnings on macOS.
2023-10-02 15:07:55 +02:00
Nick Wellnhofer
1734d27dca
encoding: Suppress -Wcast-align warnings
2023-10-02 15:04:18 +02:00
Nick Wellnhofer
71aae4e98b
dict: Compare strings with strncmp
...
Using memcmp can result in OOB reads.
Short-lived regression found by OSS-Fuzz.
2023-10-02 14:52:40 +02:00