web/lib/django/contrib/gis/gdal/libgdal.py
author ymh <ymh.work@gmail.com>
Tue, 15 Mar 2011 10:34:41 +0100
changeset 65 3d18d15135f1
parent 38 77b6da96e6f1
permissions -rw-r--r--
put video url in segment object
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
38
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
import os, re, sys
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
from ctypes import c_char_p, CDLL
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
from ctypes.util import find_library
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
from django.contrib.gis.gdal.error import OGRException
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
# Custom library path set?
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
try:
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
    from django.conf import settings
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
    lib_path = settings.GDAL_LIBRARY_PATH
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
except (AttributeError, EnvironmentError, ImportError):
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
    lib_path = None
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
if lib_path:
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
    lib_names = None
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
elif os.name == 'nt':
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
    # Windows NT shared library
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
    lib_names = ['gdal16', 'gdal15']
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
elif os.name == 'posix':
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
    # *NIX library names.
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
    lib_names = ['gdal', 'GDAL', 'gdal1.6.0', 'gdal1.5.0', 'gdal1.4.0']
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
else:
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
    raise OGRException('Unsupported OS "%s"' % os.name)
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
# Using the ctypes `find_library` utility  to find the 
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
# path to the GDAL library from the list of library names.
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
if lib_names:
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
    for lib_name in lib_names:
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
        lib_path = find_library(lib_name)
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
        if not lib_path is None: break
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
        
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
if lib_path is None:
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
    raise OGRException('Could not find the GDAL library (tried "%s"). '
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
                       'Try setting GDAL_LIBRARY_PATH in your settings.' % 
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
                       '", "'.join(lib_names))
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
# This loads the GDAL/OGR C library
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
lgdal = CDLL(lib_path)
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
# On Windows, the GDAL binaries have some OSR routines exported with 
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
# STDCALL, while others are not.  Thus, the library will also need to 
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
# be loaded up as WinDLL for said OSR functions that require the 
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
# different calling convention.
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
if os.name == 'nt':
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
    from ctypes import WinDLL
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
    lwingdal = WinDLL(lib_path)
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
def std_call(func):
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
    """
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
    Returns the correct STDCALL function for certain OSR routines on Win32
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
    platforms.
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
    """
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
    if os.name == 'nt':
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
        return lwingdal[func]
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
    else:
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
        return lgdal[func]
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
#### Version-information functions. ####
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
# Returns GDAL library version information with the given key.
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
_version_info = std_call('GDALVersionInfo')
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
_version_info.argtypes = [c_char_p]
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
_version_info.restype = c_char_p
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
def gdal_version():
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
    "Returns only the GDAL version number information."
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
    return _version_info('RELEASE_NAME')
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
def gdal_full_version(): 
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
    "Returns the full GDAL version information."
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
    return _version_info('')
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
def gdal_release_date(date=False): 
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
    """
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
    Returns the release date in a string format, e.g, "2007/06/27".
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
    If the date keyword argument is set to True, a Python datetime object
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
    will be returned instead.
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
    """
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
    from datetime import date as date_type
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
    rel = _version_info('RELEASE_DATE')
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
    yy, mm, dd = map(int, (rel[0:4], rel[4:6], rel[6:8]))
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
    d = date_type(yy, mm, dd)
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
    if date: return d
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
    else: return d.strftime('%Y/%m/%d')
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
version_regex = re.compile(r'^(?P<major>\d+)\.(?P<minor>\d+)(\.(?P<subminor>\d+))?')
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
def gdal_version_info():
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
    ver = gdal_version()
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
    m = version_regex.match(ver)
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
    if not m: raise OGRException('Could not parse GDAL version string "%s"' % ver)
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
    return dict([(key, m.group(key)) for key in ('major', 'minor', 'subminor')])
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
_verinfo = gdal_version_info()
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
GDAL_MAJOR_VERSION = int(_verinfo['major'])
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
GDAL_MINOR_VERSION = int(_verinfo['minor'])
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
GDAL_SUBMINOR_VERSION = _verinfo['subminor'] and int(_verinfo['subminor'])
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
GDAL_VERSION = (GDAL_MAJOR_VERSION, GDAL_MINOR_VERSION, GDAL_SUBMINOR_VERSION)
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
del _verinfo
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
# GeoJSON support is available only in GDAL 1.5+.
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
if GDAL_VERSION >= (1, 5):
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
    GEOJSON = True
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
else:
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
    GEOJSON = False
77b6da96e6f1 update django
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104