Opened 13 years ago
Closed 9 years ago
#17756 closed New feature (wontfix)
GeoDjango missing pyspatialite support
Reported by: | Daniel Sokolowski | Owned by: | |
---|---|---|---|
Component: | GIS | Version: | dev |
Severity: | Normal | Keywords: | |
Cc: | juanpex, taylor.mitchell@…, reinout@…, sfllaw@…, Paul Garner | Triage Stage: | Someday/Maybe |
Has patch: | yes | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | yes |
Easy pickings: | no | UI/UX: | no |
Description
Pyspatialite is a modified version of pysqlite that builds sqlite with spatiliate support already in it. This module is easier to install compared to pysqlite especially when utilizing a package installer such as PIP; making GeoDjango support this package is relatively trivial.
Further Explanation:
It appears that the emergent way to run django sites is now Virtualenv+PIP. Adding support for pyspatiallite allows one to setup GeoDjango sqlite3 support utilizing PIP and hence allows for the creation of requiremnts.txt which in turn makes the project that much more portable. One can not use PIP to install pysqlite as by default it does not enable loading of sqlite extensions.
Attachments (2)
Change History (30)
comment:1 by , 13 years ago
Owner: | changed from | to
---|---|
Status: | new → assigned |
by , 13 years ago
Attachment: | patch-feb2312@1646.diff added |
---|
comment:2 by , 13 years ago
Has patch: | set |
---|
comment:4 by , 13 years ago
Cc: | added |
---|
comment:5 by , 13 years ago
Triage Stage: | Unreviewed → Accepted |
---|
comment:6 by , 13 years ago
Cc: | added |
---|
comment:7 by , 13 years ago
Can someone please mark it "Ready for checkin" ? I just applied the patch on "Django-1.5.dev17930-py2.6-dev_r17930":
$ patch -p0 < patch-feb2312\@1646.diff (Stripping trailing CRs from patch.) patching file docs/ref/contrib/gis/install.txt Hunk #1 succeeded at 66 (offset 2 lines). Hunk #2 succeeded at 461 (offset 2 lines). (Stripping trailing CRs from patch.) patching file django/db/backends/sqlite3/base.py Hunk #1 succeeded at 22 with fuzz 1. Hunk #2 succeeded at 353 (offset 13 lines). (Stripping trailing CRs from patch.) patching file django/contrib/gis/db/backends/spatialite/base.py
comment:8 by , 13 years ago
pyspatialite seems to suffer from build/install issues. See for example those logs: http://code.activestate.com/pypm/pyspatialite/
I was able to reproduce those errors on my system.
comment:9 by , 13 years ago
Note also that the following issue did not receive any feedback for two months:
http://code.google.com/p/pyspatialite/issues/detail?id=6
comment:10 by , 13 years ago
Thanks for taking the time to review it; I've looked at the error logs and the build fails as it is missing header files - unfortunately one has to use the system package management to install those as pip won't work. Also the branch is labeled experimental. I did an upgrade from 2.6 to this experimental branch here and it build properly:
gcc -pthread -shared -Wl,-O1 -Wl,-Bsymbolic-functions build/temp.linux-i686-2.6/src/module.o build/temp.linux-i686-2.6/src/connection.o build/temp.linux-i686-2.6/src/cursor.o build/temp.linux-i686-2.6/src/cache.o build/temp.linux-i686-2.6/src/microprotocols.o build/temp.linux-i686-2.6/src/prepare_protocol.o build/temp.linux-i686-2.6/src/statement.o build/temp.linux-i686-2.6/src/util.o build/temp.linux-i686-2.6/src/row.o build/temp.linux-i686-2.6/amalgamation/sqlite3.o build/temp.linux-i686-2.6/amalgamation/spatialite.o -L/Library/Frameworks/GEOS.framework/unix/lib -L/Library/Frameworks/PROJ.framework/unix/lib -lgeos -lgeos_c -lproj -o build/lib.linux-i686-2.6/pyspatialite/_spatialite.so
Successfully installed pyspatialite
Your second concern again results in header files missing; in this case it's the geos package - see line amalgamation\spatialite.c:102:20: error: geos_c.h: No such file or directory.
Both results are due to the fact PIP only does python packages and it won't even complain if 'outside' requirements are missing, these supporting header files would need to be installed either way to compile sqlite3 with 'extension' support.
The patch ought to include a NOTE advising that one must install supporting GEOS, GDAL, PROJ.4 files? Since these issues are not package related after that it should be good for RFC. thoughts?
comment:11 by , 13 years ago
Patch needs improvement: | set |
---|
Yes, please, provide any complementary instructions for system libraries needed. What's strange with my system is that such libraries are installed, as I'm running Geodjango/Postgis without problems. It might be an issue with library paths.
comment:12 by , 13 years ago
Will do; on a side note is your system Debian, Ubuntu? If so source files and binary files are split up, i.e. libgeos libgeos-dev.
comment:13 by , 13 years ago
Yes, Debian. And you are right, the -dev packages are not installed, so that should be part of the complementary instructions.
comment:14 by , 13 years ago
Documentation updated and a pull requested created: https://github.com/django/django/pull/198
comment:15 by , 13 years ago
Thanks, we are close now. But I think that the docs are still not clear enough about what steps are needed to install SpatiaLite. The subsections are currently:
- SQLite
- SpatiaLite library (libspatialite) and tools (spatialite)
- pyspatialite
- pysqlite2
AFAIR, the pyspatialite method does not need any other step, right? In that case, wouldn't it be better to structure the section this way:
- pyspatialite
- Installing from sources
- SQLite
- SpatiaLite library (libspatialite) and tools (spatialite)
- pysqlite2
comment:16 by , 13 years ago
In all honestly when I was updating the docs I was thinking that the install docs need to be overhauled. The install from source should be removed and replaced with concise installs for specific database + linux combo using PIP and system package installers.
GeoDjango installation is overly confusing but does not need to be, I was think along the lines:
- Requirements Overview
- Django + PostgreSQL + GeoDjango Stack
- Debian/Ubuntu
- CentOS/RedHat
- ...
- Django + MySQL + GeoDjango Stack
- Debian/Ubuntu
- CentOS/RedHat
- ...
- Django + !SQLite + GeoDjango Stack
- Debian/Ubuntu
- CentOS/RedHat
- ...
Thoughts ?
comment:17 by , 13 years ago
Sure, feel free to propose a reorganisation of the install docs. However, I'd prefer not mixing patches, and this could happen in a separate ticket.
comment:18 by , 13 years ago
I tested the pull request 198 with pyspatialite on Ubuntu 12.04. What I did:
sudo apt-get install libgeos-dev sudo pip install pyspatialite ./runtests --settings=test_spatialite.py gis
Result was a core dump. Output (but not the actual dump) attached.
Of course, I can't apply the PR as the above issue needs some resolution first.
Additionally, please check the install.txt changes for whitespace errors, lines longer than 80 chars and use spaces instead of tabs.
comment:19 by , 12 years ago
Cc: | added |
---|
comment:20 by , 12 years ago
Cc: | added |
---|
comment:21 by , 11 years ago
Easy pickings: | unset |
---|
comment:22 by , 11 years ago
Owner: | removed |
---|---|
Status: | assigned → new |
Triage Stage: | Accepted → Someday/Maybe |
I no longer believe there is a need for this patch - installing through Debian apt system all the requirements as stated by the docs bypasses all of the PIP issues I have encountered and makes this not needed fix at least for me; however feel free to change it.
follow-up: 26 comment:23 by , 11 years ago
Cc: | added |
---|
Just dropping in to say anything that can ease the pain of setting up GeoDjango is much appreciated. I'm trying to do it primarily via Homebrew and Pip... it'd be nice if it worked. The current instructions all lead to various dead ends
I'm currently stuck here:
http://stackoverflow.com/questions/11093593/python-the-pysqlite-library-does-not-support-c-extension-loading
If using pip install pyspatialite
makes things more 'just work' then PLEASE do it. It's not helpful to say oh yeah I got my install working through Debian apt... it has zero value to users not on Debian.
Can a core dev please set this back to 'Accepted' as it had previously been marked?
comment:24 by , 11 years ago
Well after actually trying to apply the patch and go this route I think there are more problems. Basically pyspatialite is broken.
https://code.google.com/p/pyspatialite/issues/detail?id=5
https://code.google.com/p/pyspatialite/issues/detail?id=9
comment:25 by , 11 years ago
As a note, it's being/is fixed (at the moment, there is a new pre-release package on pypi. after a bit of testing, I'll upgrade it to stable)
comment:26 by , 11 years ago
Replying to anentropic:
Just dropping in to say anything that can ease the pain of setting up GeoDjango is much appreciated. I'm trying to do it primarily via Homebrew and Pip... it'd be nice if it worked. The current instructions all lead to various dead ends
I'm currently stuck here:
http://stackoverflow.com/questions/11093593/python-the-pysqlite-library-does-not-support-c-extension-loading
The answer to that SO question is the same as the one the Geodjango docs have mentioned for some time: https://docs.djangoproject.com/en/1.6/ref/contrib/gis/install/spatialite/#pysqlite2
[...]
Can a core dev please set this back to 'Accepted' as it had previously been marked?
Having tried the pyspatialite path myself recently, even with the latest development code, and getting the segmentation faults Anssi mentioned in comment:18 back in Jul '12 when trying to execute syncdb seems to indicate that it hasn't yet reached a point where we can:
- Support pypatialite by replacing the module used by the main SQLite Django DB backend.
- Recommend it as the easiest path to get GIS support with SQLite.
and that the documented process of using platform-packages plus possibly building pysqlite2 with a modified configuration still is the safest strategy to reach success.
Because of this, I think the 'someday/maybe' tag is appropiate at this point.
comment:27 by , 11 years ago
I am still unable to install Spatialite. The solution in SO question and GeoDjango docs mentioned above don't work for me. Full details here:
http://stackoverflow.com/questions/20505665/install-spatialite-for-python-geodjango-on-os-x
comment:28 by , 9 years ago
Resolution: | → wontfix |
---|---|
Status: | new → closed |
pysqlite 2.7.0+ can be installed using pip as C extension loading is now enabled by default. I believe that removes the motivation for this ticket.
Code + Doc patch