Addendum to #764548: restore 2.1 compatibility.
diff --git a/Lib/sre.py b/Lib/sre.py
index 7910c83..ffe2bc3 100644
--- a/Lib/sre.py
+++ b/Lib/sre.py
@@ -221,7 +221,7 @@
     pattern, flags = key
     if isinstance(pattern, _pattern_type):
         return pattern
-    if not isinstance(pattern, sre_compile.STRING_TYPES):
+    if not sre_compile.isstring(pattern):
         raise TypeError, "first argument must be string or compiled pattern"
     try:
         p = sre_compile.compile(pattern, flags)
diff --git a/Lib/sre_compile.py b/Lib/sre_compile.py
index 96f337a..8a26a0f 100644
--- a/Lib/sre_compile.py
+++ b/Lib/sre_compile.py
@@ -431,10 +431,16 @@
 try:
     unicode
 except NameError:
-    STRING_TYPES = type("")
+    STRING_TYPES = (type(""),)
 else:
     STRING_TYPES = (type(""), type(unicode("")))
 
+def isstring(obj):
+    for tp in STRING_TYPES:
+        if isinstance(obj, tp):
+            return 1
+    return 0
+
 def _code(p, flags):
 
     flags = p.pattern.flags | flags
@@ -453,7 +459,7 @@
 def compile(p, flags=0):
     # internal: convert pattern list to internal format
 
-    if isinstance(p, STRING_TYPES):
+    if isstring(p):
         import sre_parse
         pattern = p
         p = sre_parse.parse(p, flags)