X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fmatita%2Fmatita.txt;h=9026e63b34acc4353543d350f63317c808ea4092;hb=db88f09dfd6da59000c93e2ea1ea8565ec8e101d;hp=914de2d4f2de297b8ee971ea872d1e0d1f93dffa;hpb=028094be3e6de1765a0927a4ebb5c91ae035efe8;p=helm.git diff --git a/helm/matita/matita.txt b/helm/matita/matita.txt index 914de2d4f..9026e63b3 100644 --- a/helm/matita/matita.txt +++ b/helm/matita/matita.txt @@ -1,77 +1,120 @@ +TODO + NUCLEO + - PREOCCUPANTE: per + inductive i : Prop := K : True (*-> i*) -> i. + noi generiamo i_rec e i_rect con e senza il commento qui sopra; Coq NON + genera i_rec e i_rect quando c'e' un argomento ricorsivo. + (CSC: manca vincolo aggiuntivo non dipendente dalla sorta per il caso in + questione) -> CSC + - bug universi e tipi induttivi + - Set predicativo + -(**********************************************************************) + TATTICHE + - theorem t: True. elim x. ==> BOOM! unificazione di una testa flessibile con + True. + - parsing contestuale (tattiche replace, change e forse altre) + capire dove fare la select per avere i contesti in cui disambiguare gli + altri argomenti. + - assiomi (manca sintassi concreta e AST). + - Guardare il commento + (*CSC: this code is suspect and/or bugged: we try first without reduction + and then using whd. However, the saturate_term always tries with full + reduction without delta. *) + in primitiveTactics.ml. Potrebbe essere causa di rallentamento della apply + oltre che di bug! + - Dare errore significativo al posto di NotWellTypedInterpreation -> CSC + - elim_intros_simpl e rewrite_simpl: ora non viene usata dal + ^^^^^^ ^^^^^^ + toplevel la variante che semplifica. Capire quali sono i problemi + e/o cosa fare delle varianti con semplificazione. + (con sintassi concreta alla \section*, analogamente cut e similia che fanno + intros... ) -> CSC + - eta_expand non usata da nessuno? (ask Andrea?) + - eliminare eta_fix? (aspettare notazione) (correlato con sopra?) + - bug di ferruccio: fare un refresh dei nomi dopo l'applicazione + di una tattica. Di quali nomi fare refresh? (Andrea) di quelli + veramente ambigui, ovvero dell'ultimo binder tale che sotto di + esso un nome viene usato in maniera ambigua. Esempio: + \lambda x. \lambda x. (x x) (dove una x e' -2) ==> fare refresh + \lambda x. \lambda x. (x x) (dove entrambe sono -1) ==> non fare refresh + Capita quando un tipo dall'environment (e.g. \lambda x.T) + viene inserito in un contesto (e.g. x:nat) dove le variabili + sono gia' state legate in precedenza. + - supportare l'apertura di piu' script contemporaneamente in tab/finestre + diversi/e -TODO + + GUI GRAFICA + - cut&paste stile "X": rimane la parte blu e lockata! + - integrare il famoso logo mancante (anche nell'About dialog) + - invertibilita' dell'inserimento automatico di alias: quando si torna + su bisognerebbe tornare su di un passo e non fare undo degli alias + (Zack: nella history ci sono anche gli offset per sapere a che pezzo di + script uno stato appartiene) + - keybinding globali: CTRL-{su,giu,...} devono fungere anche quando altre + finestre hanno il focus (e.g. cicBrowser). C'e' gia' da qualche parte il + codice che aggiunge i keybinding a tutte le eventBox, e' da ripristinare + + - menu contestuale (tasto dx) nel sequent viewer + - feedback su hyperlink nei sequenti e nel browser: rendere visibili gli + hyperlink (cursore a "manina"? hyperlink evidenziati?). La maction che + collassa la prova e' fastidiosa: la prova si chiude se non si clicca + correttamente su un hyperlink (anche tooltip sui bottoni) + + - bug di refresh del widget quando si avanza ("swap" tra la finestra dei + sequenti e la finestra dello script) + - sensitiveness per goto begin/end/etc. (???) + - che farne della palette delle tattiche? + - script outline -> Zack + - riattaccare hbugs (brrr...) -> Zack + + GUI LOGICA + - matitamake foo/a.ma non funziona; bisogna chiamarlo con + matitamake /x/y/z/foo/a.ma + - notazione -> Luca e Zack + - non chiudere transitivamente i moo ?? + +DONE +- highlight degli errori di parsing nello script -> CSC +- quando si fa una locate nel cicbrowser viene mangiato un pezzo di testo + dalla finestra principale!!! -> CSC +- sensitiveness per copy/paste/cut/delete nel menu Edit -> CSC +- fare "matita foo" (dove foo non esiste), cambiare qualcosa e uscire senza + salvare. In verita' foo e' stato scritto lo stesso! -> CSC +- matitaclean deve rimuovere anche i .moo; in alternativa il makefile + non deve basarsi sui .moo per decidere se qualcosa e' stato compilato o meno + -> CSC, Gares +- matitaclean all (o matitamake cleanall) dovrebbe radere al suolo la + directory .matita -> CSC, Gares +- icone standard per zoom-in/out/= e piu' aderenza alle Gnome Interface + Guidelines (e.g. about dialog) -> CSC +- salvare la parte di testo lockata dagli effetti di undo/redo con + (shift-)ctrl-Z e anche usando il menu che si apre con il tasto destro -> CSC +- fare in modo che il testo caricato inizialmente da matita non sia + undoable (usando i metodi begin/end_not_undoable_action di gtk_source_view) + -> Gares +- Implementare menu edit: cut/copy/undo/etc. -> CSC +- gestione dei path per include: il path deve essere assoluto? da decidere ... + ( -I ?? o chiedere a matitamake la root e farci una find? ) -> Gares +- freeze durante avanzamento -> Gares, CSC +- tornare indietro (verso il cursore) in matita dovrebbe essere O(1) e non un + Undo passo passo (sembra che il collo di bottiglia sia fare iterare su ogni + uri da togliere (accorpare almeno il lavoro sul db magari aiuta) -> Gares, CSC +- quando si sposta il punto di esecuzione dello script cambiare la parte di + script visibile nella finestra dello script -> Gares, CSC +- find & replace -> Gares +- Bug di cut&paste: se si fa cut&paste di testo lockato si ottiene testo + lockato! -> Gares - Bug: non disambigua inductive i (x:nat) : bool \to Prop \def K : bool \to (i x true) \to (i x false). perche' non inserisce nat nel domain di disambiguazione. Deve esserci un bug - stupido da qualche parte -- preoccupante: per - inductive i (x:nat) : bool \to Prop \def K : bool \to (i x true) \to (i x false). - noi generiamo anche i_rec e i_rect che Coq non genera (e che NON dovrebbero - essere accettati dal nostro nucleo che invece non fa una piega!!!) -- parsing contestuale (tattiche replace, change e forse altre) -- assiomi -- Guardare il commento - (*CSC: this code is suspect and/or bugged: we try first without reduction - and then using whd. However, the saturate_term always tries with full - reduction without delta. *) - in primitiveTactics.ml. Potrebbe essere causa di rallentamento della apply - oltre che di bug! -- Bug di cut&paste: se si fa cut&paste di testo lockato si ottiene testo - lockato! -- keybinding globali: CTRL-{su,giu,...} devono fungere anche quando altre - finestre hanno il focus (e.g. cicBrowser). C'e' gia' da qualche parte il - codice che aggiunge i keybinding a tutte le eventBox, e' da ripristinare -- quando si sposta il punto di esecuzione dello script cambiare la parte di - script visibile nella finestra dello script -- Dare errore significativo al posto di NotWellTypedInterpreation -- Implementare menu edit: find/replace/cut/copy/undo/etc. -- Bug nella generazione dei principi di eliminazione: - 1. generazione nomi (usa ref incrementata localmente) -- elim_intros_simpl e rewrite_simpl: ora non viene usata dal - ^^^^^^ ^^^^^^ - toplevel la variante che semplifica. Capire quali sono i problemi - e/o cosa fare delle varianti con semplificazione. -- eta_expand non usata da nessuno? -- notazione -> Luca e Zack -- eliminare eta_fix? (aspettare notazione) -- bug di refresh del widget quando si avanza ("swap" tra la finestra dei - sequenti e la finestra dello script) -- feedback su hyperlink nei sequenti e nel browser: rendere visibili gli - hyperlink (cursore a "manina"? hyperlink evidenziati?). La maction che - collassa la prova e' fastidiosa: la prova si chiude se non si clicca - correttamente su un hyperlink -- disabilitare (set_sensitive false) menu e bottoni mentre matita sta - processando lo script per evitare interazioni pericolose -- bug di ferruccio: fare un refresh dei nomi dopo l'applicazione - di una tattica. Di quali nomi fare refresh? (Andrea) di quelli - veramente ambigui, ovvero dell'ultimo binder tale che sotto di - esso un nome viene usato in maniera ambigua. Esempio: - \lambda x. \lambda x. (x x) (dove una x e' -2) ==> fare refresh - \lambda x. \lambda x. (x x) (dove entrambe sono -1) ==> non fare refresh -- a volte genera termini con variabili legate da piu' binder - Capita quando un tipo dall'environment (e.g. \lambda x.T) - viene inserito in un contesto (e.g. x:nat) dove le variabili - sono gia' state legate in precedenza. -- script outline -> Zack -- cicBrowser: riagganciare(?) resa di termini scritti - nella URL(??) -- menu contestuale (tasto dx) nel sequent viewer -> attende notazione -- riattaccare hbugs (brrr...) -> Zack -- gestione dei path per include: il path deve essere assoluto? da decidere ... -- highlight degli errori di parsing nello script (usando lo sfondo come per la - parte lockata di testo, da ripulire quando si modifica il testo o si sposta il - punto di esecuzione) -- salvare la parte di testo lockata dagli effetti di undo/redo (come?????) -- supportare l'apertura di piu' script contemporaneamente in tab/finestre - diversi/e - -DONE + stupido da qualche parte -> CSC - Bug vari nella generazione dei principi di eliminazione: + 1. generazione nomi (usa ref incrementata localmente) -> Andrea 2. prodotti dipendenti come non-dipendenti (visibili eseguendo passo - passo il test inversion.ma) - 3. usato trucco outtype non dipendenti per il case + passo il test inversion.ma) -> CSC, Gares + 3. usato trucco outtype non dipendenti per il case -> CSC, Gares - controllo per script modificato o meno prima di uscire -> Gares - LApply deve prendere in input gli identificatori che va a generare; lascio a Ferruccio la scelta della sintassi concreta -> Ferruccio