]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/matita/matita.txt
changed default parameter values...
[helm.git] / helm / matita / matita.txt
index d1f44f3e651103c14bf7ecd9a3efb9d431679602..c968c9de9760276d51e31a0ca7a5d783488fa6a5 100644 (file)
+TODO
+  NUCLEO
+  - CRITICO (trovato anche da Ferruccio): typechecking di
+    cic:/Coq/ring/Ring_normalize/index_eq_prop.con
+    asserzione del nucleo (applicazione senza argomenti)
+  - 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
+  - simplify (e altre tattiche) non debbono zeta-espandere i let-in
+  - tattica unfold su rel a let-in bound variables
+  - 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
+  - Usare il cicbrowser per fare "Whelp instance": lui riscrive la barra
+    con la notazione alla Coq V7.0 che non riesce piu' a riparsare!
+  - 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
+  - la finestrella per i development ha i pulsanti non sensitive.
+    E' possibile fare "Build" senza selezionare nulla, ottenendo un
+    assert false
+  - l'entry "Save" da menu non e' context sensitive (ti fa salvare anche
+    quando il file non e' stato modificato)
+  - finire e rendere piu' compliant (e.g. tags gestiti in maniera anomala)
+    il Cic Browser
+  - la barra di stato: c'e' ma non funziona?
+
+  - 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)
+
+  - che farne della palette delle tattiche?
+  - script outline -> Zack
+  - riattaccare hbugs (brrr...) -> Zack
+
+  GUI LOGICA
+  - fattorizzare codice fra MatitaEngine e DisambiguatePp (dove, fra l'altro,
+    ora io (=CSC) ho messo anche un parser!!!)
+  - verificare se tutte le query sono ora ottimizzate (usando il comando
+    explain) e usano gli indici in maniera ottimale; inoltre migliorare gli
+    indici sulle tabelle hits and count
+  - ???????????? Perche'?
+    mowgli:~# du -s /var/lib/mysql/mowgli/
+    250696  /var/lib/mysql/mowgli/
+    mowgli:~# du -s /var/lib/mysql/matita/
+    455096  /var/lib/mysql/matita/
+  - integrare nuova contrib ferruccio nel bench notturno; guardare bug
+    generazione principi di eliminazione
+  - bug "Warn:  baseuri cic:/matita/higher_order_defs/ordering is not empty"
+    mentre si compila Z/times.ma. Il bug sembra essere transiente.
+  - in MatitaEngine unificare/rimuovere eval_string, eval_from_stream e
+    eval_from_stream_greedy
+  - disambiguazione: attualmente io (CSC) ho committato la versione di
+    disambiguate.ml che NON ricorda gli alias in caso di disambiguazione
+    univoca (senza scelte per l'utente). [ cercare commento "Experimental" ]
+    Il problema di questa soluzione e' che rallenta in maniera significativa
+    l'esecuzione degli script. DOMANDA: quanto costano le fasi di
+    fetch/decode/execute delle linee dello script?
+    Una possibile alternativa e' avere alias "soft": se la disambiguazione
+    fallisce gli alias soft vengono ripuliti e si riprova.
+    SOLUZIONE PENSATA CON ANDREA: 1. la interpretate aggiunge un alias
+    implicito; 2. gli alias vengono ricordati come nella soluzione originale
+    (e veloce); 3. se la disambiguazione fallisce, allora gli alias vengono
+    dimenticati (quali? tutti?) e si ritenta; se fallisce ancora si generano
+    istanze differenti e si ritenta; 4. ritentare anche senza e poi con
+    coercions? oppure ordinare preferendo la soluzione che non ha introdotto
+    coercions?; 5. che fare se alla fine restano piu' scelte? se si mettono
+    gli alias nello script viene un paciugo, credo! in particolare quando
+    vengono usate n istanze
+  - 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 ?? 
+
+  DEMONI E ALTRO
+  - implementare inclusione file di configurazione (perche' ora tutti
+    i demoni scopiazzano venti righe per via del getter embedded :-(
+
+DONE
+- library/nat/primes.ma: ex_prime ci mette un secolo il db (binding) a fare
+  la Mysql.exec che ritorna una lista vuota di risultati. Investigare.
+  Anche peggio in library/nat/minimization/f_max_true. -> CSC
+- integrare il famoso logo mancante (anche nell'About dialog) -> CSC
+- 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) -> CSC
+- bug di refresh del widget quando si avanza ("swap" tra la finestra dei
+  sequenti e la finestra dello script) -> CSC
+- sensitiveness per goto begin/end/etc. (???) -> Gares
+- cut&paste stile "X": rimane la parte blu e lockata! -> CSC
+- 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.
+  stupido da qualche parte -> CSC
 - Bug vari nella generazione dei principi di eliminazione:
-   1. generazione nomi (usa ref incrementata localmente)
+   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
-- 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
+      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