[1.8.x] Fixed #24724 -- Fixed GIS initialization crash on Windows.

Backport of 3c4fca271b from master
This commit is contained in:
Tim Graham 2015-04-29 08:57:50 -04:00
parent 77ed1548f2
commit d7ea279f76
2 changed files with 42 additions and 37 deletions

View File

@ -5,7 +5,7 @@ related data structures.
from ctypes import POINTER, c_char_p, c_double, c_int, c_void_p from ctypes import POINTER, c_char_p, c_double, c_int, c_void_p
from functools import partial from functools import partial
from django.contrib.gis.gdal.libgdal import lgdal from django.contrib.gis.gdal.libgdal import std_call
from django.contrib.gis.gdal.prototypes.generation import ( from django.contrib.gis.gdal.prototypes.generation import (
const_string_output, double_output, int_output, void_output, const_string_output, double_output, int_output, void_output,
voidptr_output, voidptr_output,
@ -21,45 +21,47 @@ const_string_output = partial(const_string_output, cpl=True)
double_output = partial(double_output, cpl=True) double_output = partial(double_output, cpl=True)
# Raster Driver Routines # Raster Driver Routines
register_all = void_output(lgdal.GDALAllRegister, []) register_all = void_output(std_call('GDALAllRegister'), [])
get_driver = voidptr_output(lgdal.GDALGetDriver, [c_int]) get_driver = voidptr_output(std_call('GDALGetDriver'), [c_int])
get_driver_by_name = voidptr_output(lgdal.GDALGetDriverByName, [c_char_p], errcheck=False) get_driver_by_name = voidptr_output(std_call('GDALGetDriverByName'), [c_char_p], errcheck=False)
get_driver_count = int_output(lgdal.GDALGetDriverCount, []) get_driver_count = int_output(std_call('GDALGetDriverCount'), [])
get_driver_description = const_string_output(lgdal.GDALGetDescription, [c_void_p]) get_driver_description = const_string_output(std_call('GDALGetDescription'), [c_void_p])
# Raster Data Source Routines # Raster Data Source Routines
create_ds = voidptr_output(lgdal.GDALCreate, [c_void_p, c_char_p, c_int, c_int, c_int, c_int]) create_ds = voidptr_output(std_call('GDALCreate'), [c_void_p, c_char_p, c_int, c_int, c_int, c_int, c_void_p])
open_ds = voidptr_output(lgdal.GDALOpen, [c_char_p, c_int]) open_ds = voidptr_output(std_call('GDALOpen'), [c_char_p, c_int])
close_ds = void_output(lgdal.GDALClose, [c_void_p]) close_ds = void_output(std_call('GDALClose'), [c_void_p])
copy_ds = voidptr_output(lgdal.GDALCreateCopy, [c_void_p, c_char_p, c_void_p, c_int, copy_ds = voidptr_output(std_call('GDALCreateCopy'),
POINTER(c_char_p), c_void_p, c_void_p]) [c_void_p, c_char_p, c_void_p, c_int, POINTER(c_char_p), c_void_p, c_void_p]
add_band_ds = void_output(lgdal.GDALAddBand, [c_void_p, c_int]) )
get_ds_description = const_string_output(lgdal.GDALGetDescription, []) add_band_ds = void_output(std_call('GDALAddBand'), [c_void_p, c_int])
get_ds_driver = voidptr_output(lgdal.GDALGetDatasetDriver, [c_void_p]) get_ds_description = const_string_output(std_call('GDALGetDescription'), [c_void_p])
get_ds_xsize = int_output(lgdal.GDALGetRasterXSize, [c_void_p]) get_ds_driver = voidptr_output(std_call('GDALGetDatasetDriver'), [c_void_p])
get_ds_ysize = int_output(lgdal.GDALGetRasterYSize, [c_void_p]) get_ds_xsize = int_output(std_call('GDALGetRasterXSize'), [c_void_p])
get_ds_raster_count = int_output(lgdal.GDALGetRasterCount, [c_void_p]) get_ds_ysize = int_output(std_call('GDALGetRasterYSize'), [c_void_p])
get_ds_raster_band = voidptr_output(lgdal.GDALGetRasterBand, [c_void_p, c_int]) get_ds_raster_count = int_output(std_call('GDALGetRasterCount'), [c_void_p])
get_ds_projection_ref = const_string_output(lgdal.GDALGetProjectionRef, [c_void_p]) get_ds_raster_band = voidptr_output(std_call('GDALGetRasterBand'), [c_void_p, c_int])
set_ds_projection_ref = void_output(lgdal.GDALSetProjection, [c_void_p, c_char_p]) get_ds_projection_ref = const_string_output(std_call('GDALGetProjectionRef'), [c_void_p])
get_ds_geotransform = void_output(lgdal.GDALGetGeoTransform, [c_void_p, POINTER(c_double * 6)], errcheck=False) set_ds_projection_ref = void_output(std_call('GDALSetProjection'), [c_void_p, c_char_p])
set_ds_geotransform = void_output(lgdal.GDALSetGeoTransform, [c_void_p, POINTER(c_double * 6)]) get_ds_geotransform = void_output(std_call('GDALGetGeoTransform'), [c_void_p, POINTER(c_double * 6)], errcheck=False)
set_ds_geotransform = void_output(std_call('GDALSetGeoTransform'), [c_void_p, POINTER(c_double * 6)])
# Raster Band Routines # Raster Band Routines
band_io = void_output(lgdal.GDALRasterIO, [c_void_p, c_int, c_int, c_int, c_int, c_int, band_io = void_output(std_call('GDALRasterIO'),
c_void_p, c_int, c_int, c_int, c_int, c_int]) [c_void_p, c_int, c_int, c_int, c_int, c_int, c_void_p, c_int, c_int, c_int, c_int, c_int]
get_band_xsize = int_output(lgdal.GDALGetRasterBandXSize, [c_void_p]) )
get_band_ysize = int_output(lgdal.GDALGetRasterBandYSize, [c_void_p]) get_band_xsize = int_output(std_call('GDALGetRasterBandXSize'), [c_void_p])
get_band_index = int_output(lgdal.GDALGetBandNumber, [c_void_p]) get_band_ysize = int_output(std_call('GDALGetRasterBandYSize'), [c_void_p])
get_band_description = const_string_output(lgdal.GDALGetDescription, [c_void_p]) get_band_index = int_output(std_call('GDALGetBandNumber'), [c_void_p])
get_band_ds = voidptr_output(lgdal.GDALGetBandDataset, [c_void_p]) get_band_description = const_string_output(std_call('GDALGetDescription'), [c_void_p])
get_band_datatype = int_output(lgdal.GDALGetRasterDataType, [c_void_p]) get_band_ds = voidptr_output(std_call('GDALGetBandDataset'), [c_void_p])
get_band_nodata_value = double_output(lgdal.GDALGetRasterNoDataValue, [c_void_p, POINTER(c_int)]) get_band_datatype = int_output(std_call('GDALGetRasterDataType'), [c_void_p])
set_band_nodata_value = void_output(lgdal.GDALSetRasterNoDataValue, [c_void_p, c_double]) get_band_nodata_value = double_output(std_call('GDALGetRasterNoDataValue'), [c_void_p, POINTER(c_int)])
get_band_minimum = double_output(lgdal.GDALGetRasterMinimum, [c_void_p, POINTER(c_int)]) set_band_nodata_value = void_output(std_call('GDALSetRasterNoDataValue'), [c_void_p, c_double])
get_band_maximum = double_output(lgdal.GDALGetRasterMaximum, [c_void_p, POINTER(c_int)]) get_band_minimum = double_output(std_call('GDALGetRasterMinimum'), [c_void_p, POINTER(c_int)])
get_band_maximum = double_output(std_call('GDALGetRasterMaximum'), [c_void_p, POINTER(c_int)])
# Reprojection routine # Reprojection routine
reproject_image = void_output(lgdal.GDALReprojectImage, [c_void_p, c_char_p, c_void_p, c_char_p, reproject_image = void_output(std_call('GDALReprojectImage'),
c_int, c_double, c_double, [c_void_p, c_char_p, c_void_p, c_char_p, c_int, c_double, c_double, c_void_p, c_void_p, c_void_p]
c_void_p, c_void_p, c_void_p]) )

View File

@ -84,6 +84,9 @@ Bugfixes
``ModelAdmin.filter_horizontal`` and ``filter_vertical`` options ``ModelAdmin.filter_horizontal`` and ``filter_vertical`` options
(:ticket:`24676`). (:ticket:`24676`).
* Fixed `AttributeError: function 'GDALAllRegister' not found` error when
initializing ``contrib.gis`` on Windows.
Optimizations Optimizations
============= =============