Commit 9b790248 authored by Olivier Bertrand's avatar Olivier Bertrand

- Add routine to test index equality

modified:
  storage/connect/ha_connect.cc
  storage/connect/ha_connect.h
  storage/connect/xindex.h
parent 6be6b4ab
...@@ -2988,6 +2988,30 @@ err: ...@@ -2988,6 +2988,30 @@ err:
return true; return true;
} }
// Check that two indexes are equivalent
bool ha_connect::IsSameIndex(PIXDEF xp1, PIXDEF xp2)
{
bool b= true;
PKPDEF kp1, kp2;
if (stricmp(xp1->Name, xp2->Name))
b= false;
else if (xp1->Nparts != xp2->Nparts ||
xp1->MaxSame != xp2->MaxSame ||
xp1->Unique != xp2->Unique)
b= false;
else for (kp1= xp1->ToKeyParts, kp2= xp2->ToKeyParts;
b && (kp1 || kp2);
kp1= kp1->Next, kp2= kp2->Next)
if (!kp1 || !kp2)
b= false;
else if (stricmp(kp1->Name, kp2->Name))
b= false;
else if (kp1->Klen != kp2->Klen)
b= false;
return b;
} // end of IsSameIndex
/** /**
@brief @brief
...@@ -3074,7 +3098,7 @@ int ha_connect::external_lock(THD *thd, int lock_type) ...@@ -3074,7 +3098,7 @@ int ha_connect::external_lock(THD *thd, int lock_type)
for (xp2= oldpix; xp2; xp2= xp) { for (xp2= oldpix; xp2; xp2= xp) {
for (xp1= newpix; xp1; xp1= xp1->Next) for (xp1= newpix; xp1; xp1= xp1->Next)
if (!stricmp(xp1->Name, xp2->Name)) if (IsSameIndex(xp1, xp2))
break; // Index not to drop break; // Index not to drop
xp= xp2->GetNext(); xp= xp2->GetNext();
...@@ -3107,7 +3131,7 @@ int ha_connect::external_lock(THD *thd, int lock_type) ...@@ -3107,7 +3131,7 @@ int ha_connect::external_lock(THD *thd, int lock_type)
for (xp1= newpix; xp1; xp1= xp) { for (xp1= newpix; xp1; xp1= xp) {
for (xp2= oldpix; xp2; xp2= xp2->Next) for (xp2= oldpix; xp2; xp2= xp2->Next)
if (!stricmp(xp1->Name, xp2->Name)) if (IsSameIndex(xp1, xp2))
break; // Index already made break; // Index already made
xp= xp1->Next; xp= xp1->Next;
......
...@@ -109,6 +109,7 @@ public: ...@@ -109,6 +109,7 @@ public:
char *GetColName(Field *fp); char *GetColName(Field *fp);
void AddColName(char *cp, Field *fp); void AddColName(char *cp, Field *fp);
TABLE *GetTable(void) {return table;} TABLE *GetTable(void) {return table;}
bool IsSameIndex(PIXDEF xp1, PIXDEF xp2);
PCONNECT GetUser(THD *thd); PCONNECT GetUser(THD *thd);
PGLOBAL GetPlug(THD *thd); PGLOBAL GetPlug(THD *thd);
......
...@@ -147,6 +147,7 @@ class DllExport KPARTDEF : public BLOCK { /* Index Key Part desc block */ ...@@ -147,6 +147,7 @@ class DllExport KPARTDEF : public BLOCK { /* Index Key Part desc block */
friend class XINDEX; friend class XINDEX;
friend class PLUGCAT; friend class PLUGCAT;
friend class DOSDEF; friend class DOSDEF;
friend class ha_connect;
friend int PlgMakeIndex(PGLOBAL g, PSZ name, PIXDEF pxdf, bool add); friend int PlgMakeIndex(PGLOBAL g, PSZ name, PIXDEF pxdf, bool add);
public: public:
KPARTDEF(PSZ name, int n); // Constructor KPARTDEF(PSZ name, int n); // Constructor
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment