- Notifications
You must be signed in to change notification settings - Fork5
Commitcacd42d
committed
Rewrite libxml error handling to be more robust.
libxml reports some errors (like invalid xmlns attributes) via the errorhandler hook, but still returns a success indicator to the library caller.This causes us to miss some errors that are important to report. Since the"generic" error handler hook doesn't know whether the message it's gettingis for an error, warning, or notice, stop using that and instead startusing the "structured" error handler hook, which gets enough informationto be useful.While at it, arrange to save and restore the error handler hook setting ineach libxml-using function, rather than assuming we can set and forget thehook. This should improve the odds of working nicely with third-partylibraries that also use libxml.In passing, volatile-ize some local variables that get modified withinPG_TRY blocks. I noticed this while testing with an older gcc versionthan I'd previously tried to compile xml.c with.Florian Pflug and Tom Lane, with extensive review/testing by Noah Misch1 parentd79a601 commitcacd42d
File tree
10 files changed
+939
-219
lines changed- contrib/xml2
- src
- backend/utils/adt
- include
- utils
- test/regress
- expected
- sql
10 files changed
+939
-219
lines changedLines changed: 69 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
23655 | 23655 |
| |
23656 | 23656 |
| |
23657 | 23657 |
| |
| 23658 | + | |
| 23659 | + | |
| 23660 | + | |
| 23661 | + | |
| 23662 | + | |
| 23663 | + | |
| 23664 | + | |
| 23665 | + | |
| 23666 | + | |
| 23667 | + | |
| 23668 | + | |
| 23669 | + | |
| 23670 | + | |
| 23671 | + | |
| 23672 | + | |
| 23673 | + | |
| 23674 | + | |
| 23675 | + | |
| 23676 | + | |
| 23677 | + | |
| 23678 | + | |
| 23679 | + | |
| 23680 | + | |
| 23681 | + | |
| 23682 | + | |
| 23683 | + | |
| 23684 | + | |
| 23685 | + | |
| 23686 | + | |
| 23687 | + | |
| 23688 | + | |
| 23689 | + | |
| 23690 | + | |
| 23691 | + | |
| 23692 | + | |
| 23693 | + | |
| 23694 | + | |
| 23695 | + | |
| 23696 | + | |
| 23697 | + | |
| 23698 | + | |
| 23699 | + | |
| 23700 | + | |
| 23701 | + | |
| 23702 | + | |
| 23703 | + | |
| 23704 | + | |
| 23705 | + | |
| 23706 | + | |
| 23707 | + | |
| 23708 | + | |
| 23709 | + | |
| 23710 | + | |
| 23711 | + | |
| 23712 | + | |
| 23713 | + | |
| 23714 | + | |
| 23715 | + | |
| 23716 | + | |
| 23717 | + | |
| 23718 | + | |
| 23719 | + | |
| 23720 | + | |
| 23721 | + | |
| 23722 | + | |
| 23723 | + | |
| 23724 | + | |
| 23725 | + | |
| 23726 | + | |
23658 | 23727 |
| |
23659 | 23728 |
| |
23660 | 23729 |
| |
|
Lines changed: 17 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
1519 | 1519 |
| |
1520 | 1520 |
| |
1521 | 1521 |
| |
| 1522 | + | |
| 1523 | + | |
| 1524 | + | |
| 1525 | + | |
| 1526 | + | |
| 1527 | + | |
| 1528 | + | |
| 1529 | + | |
| 1530 | + | |
| 1531 | + | |
| 1532 | + | |
| 1533 | + | |
| 1534 | + | |
| 1535 | + | |
| 1536 | + | |
| 1537 | + | |
| 1538 | + | |
1522 | 1539 |
| |
1523 | 1540 |
| |
1524 | 1541 |
| |
|
Lines changed: 93 additions & 38 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
38 | 38 |
| |
39 | 39 |
| |
40 | 40 |
| |
41 |
| - | |
| 41 | + | |
42 | 42 |
| |
43 | 43 |
| |
44 | 44 |
| |
| |||
68 | 68 |
| |
69 | 69 |
| |
70 | 70 |
| |
| 71 | + | |
| 72 | + | |
| 73 | + | |
71 | 74 |
| |
72 |
| - | |
73 |
| - | |
| 75 | + | |
| 76 | + | |
74 | 77 |
| |
| 78 | + | |
| 79 | + | |
75 | 80 |
| |
76 |
| - | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
77 | 84 |
| |
78 | 85 |
| |
79 | 86 |
| |
80 | 87 |
| |
81 | 88 |
| |
82 | 89 |
| |
| 90 | + | |
| 91 | + | |
83 | 92 |
| |
84 | 93 |
| |
85 | 94 |
| |
| |||
98 | 107 |
| |
99 | 108 |
| |
100 | 109 |
| |
| 110 | + | |
101 | 111 |
| |
102 | 112 |
| |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
103 | 129 |
| |
104 |
| - | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
105 | 133 |
| |
106 |
| - | |
107 |
| - | |
108 |
| - | |
109 |
| - | |
110 |
| - | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
111 | 137 |
| |
112 | 138 |
| |
113 | 139 |
| |
| |||
399 | 425 |
| |
400 | 426 |
| |
401 | 427 |
| |
402 |
| - | |
| 428 | + | |
403 | 429 |
| |
404 | 430 |
| |
405 | 431 |
| |
406 | 432 |
| |
407 | 433 |
| |
408 | 434 |
| |
409 |
| - | |
| 435 | + | |
410 | 436 |
| |
411 |
| - | |
412 |
| - | |
413 |
| - | |
| 437 | + | |
| 438 | + | |
| 439 | + | |
| 440 | + | |
| 441 | + | |
| 442 | + | |
| 443 | + | |
| 444 | + | |
414 | 445 |
| |
415 |
| - | |
416 |
| - | |
| 446 | + | |
| 447 | + | |
| 448 | + | |
| 449 | + | |
| 450 | + | |
417 | 451 |
| |
418 |
| - | |
419 |
| - | |
420 |
| - | |
| 452 | + | |
| 453 | + | |
| 454 | + | |
| 455 | + | |
| 456 | + | |
| 457 | + | |
| 458 | + | |
421 | 459 |
| |
422 | 460 |
| |
423 |
| - | |
424 |
| - | |
425 |
| - | |
426 | 461 |
| |
427 |
| - | |
428 |
| - | |
429 |
| - | |
| 462 | + | |
430 | 463 |
| |
431 |
| - | |
| 464 | + | |
| 465 | + | |
| 466 | + | |
432 | 467 |
| |
433 |
| - | |
| 468 | + | |
434 | 469 |
| |
435 | 470 |
| |
436 |
| - | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
437 | 474 |
| |
438 | 475 |
| |
439 | 476 |
| |
| |||
534 | 571 |
| |
535 | 572 |
| |
536 | 573 |
| |
| 574 | + | |
| 575 | + | |
537 | 576 |
| |
538 | 577 |
| |
539 | 578 |
| |
| |||
659 | 698 |
| |
660 | 699 |
| |
661 | 700 |
| |
662 |
| - | |
| 701 | + | |
663 | 702 |
| |
| 703 | + | |
| 704 | + | |
664 | 705 |
| |
665 | 706 |
| |
666 | 707 |
| |
667 | 708 |
| |
668 | 709 |
| |
669 |
| - | |
670 | 710 |
| |
671 | 711 |
| |
672 | 712 |
| |
| |||
718 | 758 |
| |
719 | 759 |
| |
720 | 760 |
| |
721 |
| - | |
722 |
| - | |
723 |
| - | |
| 761 | + | |
| 762 | + | |
724 | 763 |
| |
725 |
| - | |
726 | 764 |
| |
727 | 765 |
| |
728 | 766 |
| |
| |||
737 | 775 |
| |
738 | 776 |
| |
739 | 777 |
| |
740 |
| - | |
741 |
| - | |
| 778 | + | |
742 | 779 |
| |
743 | 780 |
| |
744 | 781 |
| |
| |||
776 | 813 |
| |
777 | 814 |
| |
778 | 815 |
| |
779 |
| - | |
| 816 | + | |
| 817 | + | |
| 818 | + | |
780 | 819 |
| |
781 | 820 |
| |
782 | 821 |
| |
783 | 822 |
| |
784 | 823 |
| |
785 | 824 |
| |
| 825 | + | |
| 826 | + | |
| 827 | + | |
| 828 | + | |
| 829 | + | |
| 830 | + | |
| 831 | + | |
| 832 | + | |
| 833 | + | |
| 834 | + | |
| 835 | + | |
| 836 | + | |
| 837 | + | |
| 838 | + | |
| 839 | + | |
| 840 | + | |
786 | 841 |
| |
787 | 842 |
| |
788 | 843 |
| |
|
0 commit comments
Comments
(0)