????JFIF??x?x????'
| Server IP : 172.67.174.47  /  Your IP : 216.73.216.145 Web Server : LiteSpeed System : Linux premium151.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 User : tempvsty ( 647) PHP Version : 8.0.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /././././proc/thread-self/root/opt/alt/python312/lib64/python3.12/importlib/metadata/ | 
| Upload File : | 
import re
from ._functools import method_cache
# from jaraco.text 3.5
class FoldedCase(str):
    """
    A case insensitive string class; behaves just like str
    except compares equal when the only variation is case.
    >>> s = FoldedCase('hello world')
    >>> s == 'Hello World'
    True
    >>> 'Hello World' == s
    True
    >>> s != 'Hello World'
    False
    >>> s.index('O')
    4
    >>> s.split('O')
    ['hell', ' w', 'rld']
    >>> sorted(map(FoldedCase, ['GAMMA', 'alpha', 'Beta']))
    ['alpha', 'Beta', 'GAMMA']
    Sequence membership is straightforward.
    >>> "Hello World" in [s]
    True
    >>> s in ["Hello World"]
    True
    You may test for set inclusion, but candidate and elements
    must both be folded.
    >>> FoldedCase("Hello World") in {s}
    True
    >>> s in {FoldedCase("Hello World")}
    True
    String inclusion works as long as the FoldedCase object
    is on the right.
    >>> "hello" in FoldedCase("Hello World")
    True
    But not if the FoldedCase object is on the left:
    >>> FoldedCase('hello') in 'Hello World'
    False
    In that case, use in_:
    >>> FoldedCase('hello').in_('Hello World')
    True
    >>> FoldedCase('hello') > FoldedCase('Hello')
    False
    """
    def __lt__(self, other):
        return self.lower() < other.lower()
    def __gt__(self, other):
        return self.lower() > other.lower()
    def __eq__(self, other):
        return self.lower() == other.lower()
    def __ne__(self, other):
        return self.lower() != other.lower()
    def __hash__(self):
        return hash(self.lower())
    def __contains__(self, other):
        return super().lower().__contains__(other.lower())
    def in_(self, other):
        "Does self appear in other?"
        return self in FoldedCase(other)
    # cache lower since it's likely to be called frequently.
    @method_cache
    def lower(self):
        return super().lower()
    def index(self, sub):
        return self.lower().index(sub.lower())
    def split(self, splitter=' ', maxsplit=0):
        pattern = re.compile(re.escape(splitter), re.I)
        return pattern.split(self, maxsplit)