Removing old patch not needed proper fix is in, Daniel
This commit is contained in:
parent
a0c4ab30b7
commit
04319b94b5
264
key.patch
264
key.patch
@ -1,264 +0,0 @@
|
|||||||
Index: libxslt/keys.c
|
|
||||||
===================================================================
|
|
||||||
--- libxslt/keys.c (revision 1450)
|
|
||||||
+++ libxslt/keys.c (revision 1451)
|
|
||||||
@@ -393,9 +393,11 @@ xsltGetKey(xsltTransformContextPtr ctxt,
|
|
||||||
const xmlChar *nameURI, const xmlChar *value) {
|
|
||||||
xmlNodeSetPtr ret;
|
|
||||||
xsltKeyTablePtr table;
|
|
||||||
+#if 0
|
|
||||||
#ifdef XSLT_REFACTORED_KEYCOMP
|
|
||||||
int found = 0;
|
|
||||||
#endif
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
if ((ctxt == NULL) || (name == NULL) || (value == NULL) ||
|
|
||||||
(ctxt->document == NULL))
|
|
||||||
@@ -406,20 +408,23 @@ xsltGetKey(xsltTransformContextPtr ctxt,
|
|
||||||
"Get key %s, value %s\n", name, value);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
+#ifdef XSLT_REFACTORED_KEYCOMP
|
|
||||||
+ if (xsltInitAllDocKeys(ctxt))
|
|
||||||
+ return(NULL);
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
table = (xsltKeyTablePtr) ctxt->document->keys;
|
|
||||||
while (table != NULL) {
|
|
||||||
if (((nameURI != NULL) == (table->nameURI != NULL)) &&
|
|
||||||
xmlStrEqual(table->name, name) &&
|
|
||||||
xmlStrEqual(table->nameURI, nameURI))
|
|
||||||
{
|
|
||||||
-#ifdef XSLT_REFACTORED_KEYCOMP
|
|
||||||
- found = 1;
|
|
||||||
-#endif
|
|
||||||
ret = (xmlNodeSetPtr)xmlHashLookup(table->keys, value);
|
|
||||||
return(ret);
|
|
||||||
}
|
|
||||||
table = table->next;
|
|
||||||
}
|
|
||||||
+#if 0
|
|
||||||
#ifdef XSLT_REFACTORED_KEYCOMP
|
|
||||||
if (! found) {
|
|
||||||
xsltStylesheetPtr style = ctxt->style;
|
|
||||||
@@ -464,6 +469,7 @@ xsltGetKey(xsltTransformContextPtr ctxt,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
+#endif
|
|
||||||
return(NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -553,6 +559,77 @@ xsltEvalXPathKeys(xsltTransformContextPt
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
+#ifdef XSLT_REFACTORED_KEYCOMP
|
|
||||||
+/**
|
|
||||||
+ * xsltInitAllDocKeys:
|
|
||||||
+ *
|
|
||||||
+ * INTERNAL ROUTINE ONLY
|
|
||||||
+ *
|
|
||||||
+ * Check if any keys on the current document need to be computed
|
|
||||||
+ */
|
|
||||||
+int
|
|
||||||
+xsltInitAllDocKeys(xsltTransformContextPtr ctxt)
|
|
||||||
+{
|
|
||||||
+ xsltStylesheetPtr style, style2;
|
|
||||||
+ xsltKeyDefPtr keyd, keyd2;
|
|
||||||
+ xsltKeyTablePtr table;
|
|
||||||
+
|
|
||||||
+ if (ctxt == NULL)
|
|
||||||
+ return(-1);
|
|
||||||
+
|
|
||||||
+ if (ctxt->document->nbKeysComputed == ctxt->nbKeys)
|
|
||||||
+ return(0);
|
|
||||||
+ /*
|
|
||||||
+ * TODO: This could be further optimized
|
|
||||||
+ */
|
|
||||||
+ style = ctxt->style;
|
|
||||||
+ while (style) {
|
|
||||||
+ keyd = (xsltKeyDefPtr) style->keys;
|
|
||||||
+ while (keyd != NULL) {
|
|
||||||
+ /*
|
|
||||||
+ * Check if keys with this QName have been already
|
|
||||||
+ * computed.
|
|
||||||
+ */
|
|
||||||
+ table = (xsltKeyTablePtr) ctxt->document->keys;
|
|
||||||
+ while (table) {
|
|
||||||
+ if (((keyd->nameURI != NULL) == (table->nameURI != NULL)) &&
|
|
||||||
+ xmlStrEqual(keyd->name, table->name) &&
|
|
||||||
+ xmlStrEqual(keyd->nameURI, table->nameURI))
|
|
||||||
+ {
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+ table = table->next;
|
|
||||||
+ }
|
|
||||||
+ if (table == NULL) {
|
|
||||||
+ /*
|
|
||||||
+ * Keys with this QName have not been yet computed.
|
|
||||||
+ */
|
|
||||||
+ style2 = ctxt->style;
|
|
||||||
+ while (style2 != NULL) {
|
|
||||||
+ keyd2 = (xsltKeyDefPtr) style2->keys;
|
|
||||||
+ while (keyd2 != NULL) {
|
|
||||||
+ if (((keyd2->nameURI != NULL) ==
|
|
||||||
+ (keyd->nameURI != NULL)) &&
|
|
||||||
+ xmlStrEqual(keyd2->name, keyd->name) &&
|
|
||||||
+ xmlStrEqual(keyd2->nameURI, keyd->nameURI))
|
|
||||||
+ {
|
|
||||||
+ xsltInitCtxtKey(ctxt, ctxt->document, keyd2);
|
|
||||||
+ if (ctxt->document->nbKeysComputed == ctxt->nbKeys)
|
|
||||||
+ return(0);
|
|
||||||
+ }
|
|
||||||
+ keyd2 = keyd2->next;
|
|
||||||
+ }
|
|
||||||
+ style2 = xsltNextImport(style2);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ keyd = keyd->next;
|
|
||||||
+ }
|
|
||||||
+ style = xsltNextImport(style);
|
|
||||||
+ }
|
|
||||||
+ return(0);
|
|
||||||
+}
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
/**
|
|
||||||
* xsltInitCtxtKey:
|
|
||||||
* @ctxt: an XSLT transformation context
|
|
||||||
Index: libxslt/xsltInternals.h
|
|
||||||
===================================================================
|
|
||||||
--- libxslt/xsltInternals.h (revision 1450)
|
|
||||||
+++ libxslt/xsltInternals.h (revision 1451)
|
|
||||||
@@ -1958,7 +1958,8 @@ XSLTPUBFUN int XSLTCALL
|
|
||||||
xsltInitCtxtKey (xsltTransformContextPtr ctxt,
|
|
||||||
xsltDocumentPtr doc,
|
|
||||||
xsltKeyDefPtr keyd);
|
|
||||||
-
|
|
||||||
+XSLTPUBFUN int XSLTCALL
|
|
||||||
+ xsltInitAllDocKeys (xsltTransformContextPtr ctxt);
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
Index: libxslt/pattern.c
|
|
||||||
===================================================================
|
|
||||||
--- libxslt/pattern.c (revision 1450)
|
|
||||||
+++ libxslt/pattern.c (revision 1451)
|
|
||||||
@@ -2242,10 +2242,6 @@ xsltAddTemplate(xsltStylesheetPtr style,
|
|
||||||
static int
|
|
||||||
xsltComputeAllKeys(xsltTransformContextPtr ctxt, xmlNodePtr contextNode)
|
|
||||||
{
|
|
||||||
- xsltStylesheetPtr style, style2;
|
|
||||||
- xsltKeyDefPtr keyd, keyd2;
|
|
||||||
- xsltKeyTablePtr table;
|
|
||||||
-
|
|
||||||
if ((ctxt == NULL) || (contextNode == NULL)) {
|
|
||||||
xsltTransformError(ctxt, NULL, ctxt->inst,
|
|
||||||
"Internal error in xsltComputeAllKeys(): "
|
|
||||||
@@ -2266,57 +2262,7 @@ xsltComputeAllKeys(xsltTransformContextP
|
|
||||||
if (ctxt->document == NULL)
|
|
||||||
return(-1);
|
|
||||||
}
|
|
||||||
-
|
|
||||||
- if (ctxt->document->nbKeysComputed == ctxt->nbKeys)
|
|
||||||
- return(0);
|
|
||||||
- /*
|
|
||||||
- * TODO: This could be further optimized
|
|
||||||
- */
|
|
||||||
- style = ctxt->style;
|
|
||||||
- while (style) {
|
|
||||||
- keyd = (xsltKeyDefPtr) style->keys;
|
|
||||||
- while (keyd != NULL) {
|
|
||||||
- /*
|
|
||||||
- * Check if keys with this QName have been already
|
|
||||||
- * computed.
|
|
||||||
- */
|
|
||||||
- table = (xsltKeyTablePtr) ctxt->document->keys;
|
|
||||||
- while (table) {
|
|
||||||
- if (((keyd->nameURI != NULL) == (table->nameURI != NULL)) &&
|
|
||||||
- xmlStrEqual(keyd->name, table->name) &&
|
|
||||||
- xmlStrEqual(keyd->nameURI, table->nameURI))
|
|
||||||
- {
|
|
||||||
- break;
|
|
||||||
- }
|
|
||||||
- table = table->next;
|
|
||||||
- }
|
|
||||||
- if (table == NULL) {
|
|
||||||
- /*
|
|
||||||
- * Keys with this QName have not been yet computed.
|
|
||||||
- */
|
|
||||||
- style2 = ctxt->style;
|
|
||||||
- while (style2 != NULL) {
|
|
||||||
- keyd2 = (xsltKeyDefPtr) style2->keys;
|
|
||||||
- while (keyd2 != NULL) {
|
|
||||||
- if (((keyd2->nameURI != NULL) ==
|
|
||||||
- (keyd->nameURI != NULL)) &&
|
|
||||||
- xmlStrEqual(keyd2->name, keyd->name) &&
|
|
||||||
- xmlStrEqual(keyd2->nameURI, keyd->nameURI))
|
|
||||||
- {
|
|
||||||
- xsltInitCtxtKey(ctxt, ctxt->document, keyd2);
|
|
||||||
- if (ctxt->document->nbKeysComputed == ctxt->nbKeys)
|
|
||||||
- return(0);
|
|
||||||
- }
|
|
||||||
- keyd2 = keyd2->next;
|
|
||||||
- }
|
|
||||||
- style2 = xsltNextImport(style2);
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
- keyd = keyd->next;
|
|
||||||
- }
|
|
||||||
- style = xsltNextImport(style);
|
|
||||||
- }
|
|
||||||
- return(0);
|
|
||||||
+ return xsltInitAllDocKeys(ctxt);
|
|
||||||
|
|
||||||
doc_info_mismatch:
|
|
||||||
xsltTransformError(ctxt, NULL, ctxt->inst,
|
|
||||||
--- python/libxslt-py.c.orig 2008-04-28 17:25:21.000000000 +0200
|
|
||||||
+++ python/libxslt-py.c 2008-04-08 19:18:45.000000000 +0200
|
|
||||||
@@ -1639,6 +1639,22 @@ libxslt_xsltRegisterTmpRVT(PyObject *sel
|
|
||||||
}
|
|
||||||
|
|
||||||
PyObject *
|
|
||||||
+libxslt_xsltInitAllDocKeys(PyObject *self ATTRIBUTE_UNUSED, PyObject *args) {
|
|
||||||
+ PyObject *py_retval;
|
|
||||||
+ int c_retval;
|
|
||||||
+ xsltTransformContextPtr ctxt;
|
|
||||||
+ PyObject *pyobj_ctxt;
|
|
||||||
+
|
|
||||||
+ if (!PyArg_ParseTuple(args, (char *)"O:xsltInitAllDocKeys", &pyobj_ctxt))
|
|
||||||
+ return(NULL);
|
|
||||||
+ ctxt = (xsltTransformContextPtr) PytransformCtxt_Get(pyobj_ctxt);
|
|
||||||
+
|
|
||||||
+ c_retval = xsltInitAllDocKeys(ctxt);
|
|
||||||
+ py_retval = libxml_intWrap((int) c_retval);
|
|
||||||
+ return(py_retval);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+PyObject *
|
|
||||||
libxslt_xsltPrintErrorContext(PyObject *self ATTRIBUTE_UNUSED, PyObject *args) {
|
|
||||||
xsltTransformContextPtr ctxt;
|
|
||||||
PyObject *pyobj_ctxt;
|
|
||||||
--- doc/libxslt-api.xml.orig 2008-04-28 17:24:55.000000000 +0200
|
|
||||||
+++ doc/libxslt-api.xml 2008-04-08 19:18:48.000000000 +0200
|
|
||||||
@@ -529,6 +529,7 @@
|
|
||||||
<exports symbol='xsltAllocateExtra' type='function'/>
|
|
||||||
<exports symbol='xsltParseSequenceConstructor' type='function'/>
|
|
||||||
<exports symbol='xsltRegisterTmpRVT' type='function'/>
|
|
||||||
+ <exports symbol='xsltInitAllDocKeys' type='function'/>
|
|
||||||
<exports symbol='xsltExtensionInstructionResultFinalize' type='function'/>
|
|
||||||
<exports symbol='xsltPointerListFree' type='function'/>
|
|
||||||
<exports symbol='xsltIsBlank' type='function'/>
|
|
||||||
@@ -2337,6 +2338,11 @@ exits'/>
|
|
||||||
<info>Initializes the processor (e.g. registers built-in extensions, etc.)</info>
|
|
||||||
<return type='void'/>
|
|
||||||
</function>
|
|
||||||
+ <function name='xsltInitAllDocKeys' file='xsltInternals'>
|
|
||||||
+ <info>INTERNAL ROUTINE ONLY Check if any keys on the current document need to be computed</info>
|
|
||||||
+ <return type='int' info=''/>
|
|
||||||
+ <arg name='ctxt' type='xsltTransformContextPtr' info=''/>
|
|
||||||
+ </function>
|
|
||||||
<function name='xsltInitCtxtExts' file='extensions'>
|
|
||||||
<info>Initialize the set of modules with registered stylesheet data</info>
|
|
||||||
<return type='int' info='the number of modules initialized or -1 in case of error'/>
|
|
Loading…
Reference in New Issue
Block a user