"""
Functions for dealing with mixed-case files from case-preserving file
systems.
Todo:
  - handle patterns that already have brackets
"""
from __future__ import print_function
import os
import glob
import fnmatch
[docs]def ipat(pat):
    """Convert glob pattern to case insensitive form."""
    (dirname, pat) = os.path.split(pat)
    # Convert '/path/to/test.fpt' => '/path/to/[Tt][Ee][Ss][Tt].[]' 
    newpat = ''
    for c in pat:
        if c.isalpha:
            u = c.upper()
            l = c.lower()
            if u != l:
                newpat = newpat + '[' + u + l + ']'
            else:
                newpat += c
        else:
            newpat += c
    newpat = os.path.join(dirname, newpat)
    return newpat 
[docs]def ifnmatch(name, pat):
    """Case insensitive version of fnmatch.fnmatch()"""
    return fnmatch.fnmatch(name, ipat(pat)) 
[docs]def iglob(pat):
    """Case insensitive version of glob.glob()"""
    return glob.glob(ipat(pat)) 
[docs]def ifind(pat, ext=None):
    """Look for a file in a case insensitive way.
    Returns filename it a matching file was found, or None if it was not.
    """
    if ext:
        pat = os.path.splitext(pat)[0] + ext
    files = iglob(pat)
    if files:
        return files[0]  # Return an arbitrary file
    else:
        return None 
__all__ = ['ipat', 'ifnmatch', 'iglob', 'ifind']