Patch from Martin due to changes in joinrels.c
authorMarc G. Fournier
Mon, 3 Mar 1997 23:26:45 +0000 (23:26 +0000)
committerMarc G. Fournier
Mon, 3 Mar 1997 23:26:45 +0000 (23:26 +0000)
src/backend/optimizer/geqo/geqo_eval.c

index 74ab0e6e78dfb3e926185af84d394259a530f732..72a10ee9dfc3f0a9900a08888f28cd04b0ea9823 100644 (file)
@@ -5,7 +5,7 @@
  *
  * Copyright (c) 1994, Regents of the University of California
  *
- * $Id: geqo_eval.c,v 1.5 1997/03/01 22:22:21 momjian Exp $
+ * $Id: geqo_eval.c,v 1.6 1997/03/03 23:26:45 scrappy Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -371,10 +371,18 @@ new_joininfo_list(List *joininfo_list, List *join_relids)
     List *xjoininfo = NIL;
     
     foreach (xjoininfo, joininfo_list) {
+   List *or;
    JInfo *joininfo = (JInfo*)lfirst(xjoininfo);
 
    new_otherrels = joininfo->otherrels;
-   if (nonoverlap_sets(new_otherrels,join_relids)) {
+   foreach (or, new_otherrels)
+   {
+       if ( intMember (lfirsti(or), join_relids) )
+           new_otherrels = lremove ((void*)lfirst(or), new_otherrels);
+   }
+   joininfo->otherrels = new_otherrels;
+   if ( new_otherrels != NIL )
+   {
        other_joininfo = joininfo_member(new_otherrels,
                         current_joininfo_list);
        if(other_joininfo) {