Bug report #132
qgis crashes when viewing PostGIS tables
Status: | Closed | ||
---|---|---|---|
Priority: | Low | ||
Assignee: | Gary Sherman | ||
Category: | Data Provider | ||
Affected QGIS version: | Regression?: | No | |
Operating System: | Debian | Easy fix?: | No |
Pull Request or Patch supplied: | Resolution: | fixed | |
Crashes QGIS or corrupts data: | Copied to github as #: | 10191 |
Description
When opening a PostGIS table, in various situations we get:
Warning: QPainter::begin(): Painter is already active.
You must end() the painter before a second begin()
Segmentation fault
This happens eg if we click on the table icon after inserting a point and committing changes, or when we allow editing, select a point, and click on the "cut" icon.
In one occasion, we also got:
Warning: X Error: BadWindow (invalid Window parameter) 3
Major opcode: 20 (X_GetProperty)
Resource id: 0x1603586
before segfaulting.
History
#1 Updated by Redmine Admin over 18 years ago
After recent commit by mhugent (#5507) things have improved, but not solved; the crash does not occur in the first case (click on the table icon after inserting a point and committing changes), but it does in the second case (allow editing, select a point, and click on the "cut" icon).
#2 Updated by Marco Hugentobler over 18 years ago
I am not able to reproduce the second crash with my database. Do you have a debug version and a backtrace? Or what is the console output (besides the QPainter warning, which can be ignored)?
#3 Updated by Redmine Admin over 18 years ago
This is an strace (last lines):
ioctl(7, FIONREAD, d028a068 (SVN r33)) = 0
read(7, "\\5\\1:\\276d\\3012\\262L\\0\\0\\0\\330\\0@\\3\\0\\0\\0\\0;\\3M\\0\\22\\0"..., 32) = 32
gettimeofday({1149745938, 789955}, NULL) = 0
write(4, "\\0", 1) = 1
rt_sigprocmask(SIG_BLOCK, [PIPE], [], 8) = 0
send(10, "Q\\0\\0\\0\
end work\\0", 14, 0) = 14
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
poll([{fd=10, events=POLLIN|POLLERR, revents=POLLIN}], 1, 1) = 1 SIGSEGV (Segmentation fault) @ 0 (0) ---
recv(10, "C\\0\\0\\0\\vCOMMIT\\0Z\\0\\0\\0\\5I", 16384, 0) = 18
rt_sigprocmask(SIG_BLOCK, [PIPE], [], 8) = 0
send(10, "Q\\0\\0\\0\\17begin work\\0", 16, 0) = 16
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
poll([{fd=10, events=POLLIN|POLLERR, revents=POLLIN}], 1, -1) = 1
recv(10, "C\\0\\0\\0\
BEGIN\\0Z\\0\\0\\0\\5T", 16384, 0) = 17
rt_sigprocmask(SIG_BLOCK, [PIPE], [], 8) = 0
send(10, "Q\\0\\0\\0wdeclare qgisf binary cursor"..., 120, 0) = 120
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
poll([{fd=10, events=POLLIN|POLLERR, revents=POLLIN}], 1, -1) = 1
recv(10, "C\\0\\0\\0\\23DECLARE CURSOR\\0Z\\0\\0\\0\\5T", 16384, 0) = 26
rt_sigprocmask(SIG_BLOCK, [PIPE], [], 8) = 0
send(10, "Q\\0\\0\\0\\37fetch forward 1 from qgisf\\0", 32, 0) = 32
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
poll([{fd=10, events=POLLIN|POLLERR, revents=POLLIN}], 1, -1) = 1
recv(10, "T\\0\\0\\0C\\0\\2cat\\0\\0<\\32\\31\\0\\1\\0\\0\\0\\27\\0\\4\\377\\377\\377"..., 16384, 0) = 125
rt_sigprocmask(SIG_BLOCK, [PIPE], [], 8) = 0
send(10, "Q\\0\\0\\0\\37fetch forward 1 from qgisf\\0", 32, 0) = 32
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
poll([{fd=10, events=POLLIN|POLLERR, revents=POLLIN}], 1, -1) = 1
recv(10, "T\\0\\0\\0C\\0\\2cat\\0\\0<\\32\\31\\0\\1\\0\\0\\0\\27\\0\\4\\377\\377\\377"..., 16384, 0) = 104
--
++ killed by SIGSEGV ++
Process 18736 detached
#4 Updated by Redmine Admin over 18 years ago
apparently this has been fixed. please somebody else check it and close the bug if appropriate
#5 Updated by Gavin Macaulay - over 18 years ago
- Status changed from Open to Closed
- Resolution set to fixed
This problem appears to be resolved. Reopen if not...
#6 Updated by Anonymous over 15 years ago
Milestone Version 0.8 deleted