]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/matita/matita.txt
...
[helm.git] / helm / matita / matita.txt
index 253f107650f89d119653a62d770e69fc68362efd..d31ac70b824183e05a7f3c8e3d35ec473a0764b4 100644 (file)
@@ -11,6 +11,23 @@ TODO
     
 
   TATTICHE
+  - tattiche e fallimenti: una tattica che non progredisce dovrebbe fallire,
+    giusto?
+  - comportamento di tutte le tattiche nei confronti dei let-in
+  - tattica unfold su rel a let-in bound variables: c'e' ancora un bug
+    aperto: "unfold x in H:..." la x passata alla unfold vive nel contesto
+    del goal e non in quello del pattern. Pertanto invece di cercare di
+    fare unfolding di x viene fatto unfolding di altro.
+    Soluzione: la funzione ProofEngineHelpers.select deve tornare una
+    funzione per rilocare i termini nel contesto giusto.
+    Esempio:
+     theorem t: let uno \def S O in uno + uno = S uno \to uno=uno.
+      intros. unfold uno in H.
+    NOTA: questo bug e' legato a quello di parsing in presenza di tattiche
+    con pattern, visto che in tal caso e' l'intero parsing a dover essere
+    fatto in un contesto differente. Risolvendo quel bug si risolve
+    automaticamente anche questo.
+  - elim con pattern
   - theorem t: True. elim x. ==> BOOM! unificazione di una testa flessibile con
     True.
   - parsing contestuale (tattiche replace, change e forse altre)
@@ -46,14 +63,19 @@ TODO
 
 
   GUI GRAFICA
-  - 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)
+  - 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
@@ -61,20 +83,80 @@ TODO
     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
+  - matitaclean (e famiglia) non cancellano le directory vuote
+    (e per giunta il cicbrowser le mostra :-)
+  - codice di inizializzazione di matita, matitac, matitatop replicato e non
+    in sync
+  - fattorizzare codice fra MatitaEngine e DisambiguatePp (dove, fra l'altro,
+    ora io (=CSC) ho messo anche un parser!!!)
+  - 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.
+    Altra soluzione (Gares): avere alias multipli e provare tutti gli alias
+    multipli. Da combinare con il "ritenta con istanze multiple in caso di
+    fallimento".
+    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? tutti tranne quelli chiesti all'utente?)
+    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
+
 DONE
+- implementare inclusione file di configurazione (perche' ora tutti
+  i demoni scopiazzano venti righe per via del getter embedded :-( -> Zack
+- simplify non debbono zeta-espandere i let-in -> CSC, Gares
+- integrare nuova contrib ferruccio nel bench notturno e rilocarla in
+  contribs o qualcosa del genere -> CSC
+- CRITICO: quando l'environment non e' trusted non compila la library di
+  matita!!! -> Gares, CSC
+- bug di unsharing -> CSC
+- CRITICO (trovato anche da Ferruccio): typechecking di
+  cic:/Coq/ring/Quote/index_eq_prop.con
+  asserzione del nucleo (applicazione senza argomenti). -> CSC
+- 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 -> CSC
+- ???????????? 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/ -> CSC
+- 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