Ho una GUI piuttosto complicata scritta tramite Python tkinter
in esecuzione su linux, e uno dei componenti (che ha un widget di testo che si aggiorna di frequente) causa l'interruzione della GUI raramente (una volta al giorno).BadIDChoice RENDER in python 3.3 e tk/tcl visualizzato su X
I guis vengono visualizzati su X sia su Mac OSX che su X11 e Gnome 2.28.2 con lo stesso comportamento. La mia versione python è la 3.3 e la versione tk/tcl è 8.5. L'errore che ottengo è:
X Error of failed request: BadIDChoice (invalid resource ID chosen for this connection)
Major opcode of failed request: 148 (RENDER)
Minor opcode of failed request: 4 (RenderCreatePicture)
Resource id in failed request: 0x116517f
Serial number of failed request: 15106831
Current serial number in output stream: 15106872
un strace
assomiglia:
11:03:29.632041 recvfrom(13, 0x3bae1d4, 4096, 0, 0, 0) = -1 EAGAIN (Resource temporarily unavailable)
11:03:29.632059 recvfrom(13, 0x3bae1d4, 4096, 0, 0, 0) = -1 EAGAIN (Resource temporarily unavailable)
11:03:29.632147 poll([{fd=13, events=POLLIN|POLLOUT}], 1, -1) = 1 ([{fd=13, revents=POLLOUT}])
11:03:29.632164 writev(13, [{"\224\4\5\0D\304\361\0\17\274\361\0i\4\0\0\0\0\0\0\224\27\n\0\3\f\340\0\301\v\340\0"..., 5032}, {NULL, 0}, {"", 0}], 3) = 5032
11:03:29.632193 poll([{fd=13, events=POLLIN}], 1, -1) = 1 ([{fd=13, revents=POLLIN}])
11:03:29.637040 recvfrom(13, "\0\16\302\276x\304\361\0\4\0\224\0\1\0\0\0`\16\330\3\1\0\0\0\243\304\342\210\377\177\0\0"..., 4096, 0, NULL, NULL) = 136
11:03:29.637135 open("/usr/share/X11/XErrorDB", O_RDONLY) = 35
11:03:29.637217 fstat(35, {st_mode=S_IFREG|0644, st_size=41532, ...}) = 0
11:03:29.637360 read(35, "!\n! Copyright 1993, 1995, 1998 "..., 41532) = 41532
11:03:29.637387 close(35) = 0
11:03:29.637820 write(2, "X Error of failed request: BadI"..., 91) = 91
...
mio GUI è a thread singolo (e utilizza la chiamata after()
di monitorare prese per I/O).
Qualcuno sa cosa potrebbe essere sbagliato? C'è qualche miglior debug che potrei fare per capire cosa significa la parte X Error
?
quanti dati stanno andando nel widget di testo? cresce senza limiti o cancella vecchi dati e li sostituisce con nuovi? Stai usando molti tag? –
@BryanOakley l'output di dati/visivi cambia continuamente, ma è limitato al valore di uno schermo. Io chiamo costantemente 'textwin.delete (1.0, END); textwin.insert (END, text) '. Faccio sicuramente un uso massiccio dei tag. C'è forse un modo migliore/un altro modo in cui dovrei provare a vedere se ottengo lo stesso comportamento? – gnr
Stavo solo confermando se continui a eliminare e inserire, contro solo inserti infiniti. Sembra che probabilmente lo stai facendo bene. –