Nick Wellnhofer 01411e7c5e Check for invalid redeclarations of predefined entities
Implement section "4.6 Predefined Entities" of the XML 1.0 spec and
check whether redeclarations of predefined entities match the original
definitions.

Note that some test cases declared

    <!ENTITY lt "<">

But the XML spec clearly states that this is illegal:

> If the entities lt or amp are declared, they MUST be declared as
> internal entities whose replacement text is a character reference to
> the respective character (less-than sign or ampersand) being escaped;
> the double escaping is REQUIRED for these entities so that references
> to them produce a well-formed result.

Also fixes #217 but the connection is only tangential. The integer
overflow discovered by fuzzing was more related to the fact that various
parts of the parser disagreed on whether to prefer predefined entities
over their redeclarations. The whole situation is a mess and even
depends on legacy parser options. But now that redeclarations are
validated, it shouldn't make a difference.

As noted in the added comment, this is also one of the cases where
overly defensive checks can hide interesting logic bugs from fuzzers.
2021-02-08 21:51:26 +01:00
2020-03-08 17:41:53 +01:00
2019-09-30 18:04:38 +02:00
2021-02-07 14:39:55 +01:00
2017-11-27 14:35:29 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2017-11-27 14:35:29 +01:00
2020-03-08 17:41:53 +01:00
2020-07-23 20:46:42 +02:00
2021-02-08 17:15:44 +01:00
2014-10-13 16:06:21 +08:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2012-09-11 13:26:36 +08:00
2020-07-12 18:42:18 +02:00
2020-08-17 02:54:28 +02:00
2019-10-20 18:15:34 +02:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2012-09-11 13:26:36 +08:00
2019-09-30 18:05:45 +02:00
2019-09-30 18:04:38 +02:00
2020-08-17 01:17:39 +02:00
2019-09-30 18:04:38 +02:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-02-11 11:32:23 +01:00
2012-08-17 11:59:01 +08:00
2019-09-30 18:04:38 +02:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-11-30 11:22:53 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2019-09-30 18:04:38 +02:00
2019-09-30 18:04:38 +02:00
2020-03-08 17:41:53 +01:00
2012-05-07 15:23:25 +08:00
2019-09-30 18:04:38 +02:00
2020-03-08 17:41:53 +01:00
2019-09-30 18:04:38 +02:00
2020-08-17 01:17:39 +02:00
2020-03-08 17:41:53 +01:00
2019-09-30 18:04:38 +02:00
2012-09-11 13:26:36 +08:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2019-09-30 18:04:38 +02:00
2012-09-11 13:26:36 +08:00
2019-09-30 18:04:38 +02:00
2012-09-11 13:26:36 +08:00
2012-09-11 13:26:36 +08:00
2019-09-30 18:04:38 +02:00
2019-09-25 15:27:45 +02:00
2012-09-11 13:26:36 +08:00
2018-11-29 22:11:59 +01:00
2012-09-11 13:26:36 +08:00
2019-09-30 18:04:38 +02:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-03-08 17:41:53 +01:00
2020-11-09 18:17:01 +01:00
2020-03-08 17:41:53 +01:00
2017-11-27 14:33:37 +01:00
2019-11-11 11:29:17 +01:00
2020-03-08 17:41:53 +01:00
2020-06-15 15:23:38 +02:00
2020-03-08 17:41:53 +01:00
2019-09-30 18:04:38 +02:00
2020-08-08 20:37:30 +02:00
2019-09-30 18:04:38 +02:00
2019-09-30 18:04:38 +02:00

                  XML toolkit from the GNOME project

Full documentation is available on-line at
    http://xmlsoft.org/

This code is released under the MIT Licence see the Copyright file.

To build on an Unixised setup:
   ./configure ; make ; make install
   if the ./configure file does not exist, run ./autogen.sh instead.
To build on Windows:
   see instructions on win32/Readme.txt

To assert build quality:
   on an Unixised setup:
      run make tests
   otherwise:
       There is 3 standalone tools runtest.c runsuite.c testapi.c, which
       should compile as part of the build or as any application would.
       Launch them from this directory to get results, runtest checks 
       the proper functioning of libxml2 main APIs while testapi does
       a full coverage check. Report failures to the list.

To report bugs, follow the instructions at: 
  http://xmlsoft.org/bugs.html

A mailing-list xml@gnome.org is available, to subscribe:
    http://mail.gnome.org/mailman/listinfo/xml

The list archive is at:
    http://mail.gnome.org/archives/xml/

All technical answers asked privately will be automatically answered on
the list and archived for public access unless privacy is explicitly
required and justified.

Daniel Veillard

$Id$
Description
XML parser and toolkit
Readme 38 MiB
Languages
C 88.1%
HTML 5.8%
Python 3.6%
M4 0.5%
CMake 0.5%
Other 1.4%