]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/matita/matita.txt
removed no longer used METAs
[helm.git] / helm / matita / matita.txt
index e47e11d1b86c4dd7f499cf3e583da9836800c187..ce34e404ca1dabdbf5aefaaa24388340d78fb026 100644 (file)
@@ -1,5 +1,12 @@
+  Ferruccio ha cambiato matita.lang:
+  >      <keyword>iforall</keyword>
+  >      <keyword>iexists</keyword>
+
 TODO
   NUCLEO
+   - http://mowgli.cs.unibo.it:58084/proofCheck?uri=cic:/Coq/Reals/Rtopology/interior_P3.con
+  - i files di coq non hanno gli universi e hanno Type senza l'id numerico
+    per ora vengono considerati come con grafo vuoto... 
   - limit_mul non compila (usare test_library per testare l'intera libreria)
     (15:06:07) Zack: http://www.cs.unibo.it/cgi-bin/viewcvs.cgi/helm/gTopLevel/testlibrary.ml?rev=1.20&hideattic=0&content-type=text/vnd.viewcvs-markup
   - PREOCCUPANTE: per 
@@ -7,35 +14,30 @@ TODO
     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) -> Gares
-  - bug universi e tipi induttivi
+    questione) -> CSC, parzialmente risolto, da finire
   - Set predicativo
+  - bug universi e tipi induttivi (anche in cicElim.ml!!!)
     
-
   TATTICHE
-  - in generale: invece di spiegare gli errori nel momento in cui si sollevano
-    le eccezioni, farlo quando vengono presentate all'utente. Motivo: il calcolo
-    del messaggio di errore puo' essere estremamente costoso (e' gia' successo!)
-    quando poi il messaggio non serve!!!
-  - missing feature unification: applicazione di teoremi (~A) quando il goal
-    e' False o di teoremi $symmetric R P$ quando il goal e' $P(x,y)$.
-    Fare un passo di delta[-beta?][-iota-etc.] quando da una parte c'e' una
-    testa rigida (che si espande in una freccia)? Ma il punto e' che il bug
-    non e' di unificazione, bensi' nella fase di preparazione del goal per
-    la apply.
-  - verificare il comportamento di tutte le tattiche con il parsing lazy -> CSC
+  - coercions verso sorte:
+    1. coercere a una sorta in posizione controvariante: andare verso Prop,
+       altrimenti verso {Type,Set,CProp} (indifferentemente?)
+    2. coercere a una sorta in posizione covariante: la scelta piu' safe e'
+       andare verso Type, poi verso CProp, poi verso Set, poi verso Prop.
+       Unico problema: la scelta piu' safe e' anche quella pessima dal punto
+       di vista dell'estrazione di codice :-(
+  - fare normalize_pattern : pattern -> goal -> pattern e usarla per
+    abilitare fase 2 in fold e rewrite
+  - apply puo' generare termini non ben tipati.
+    Esempio: p = q e fare apply eq_ind' di p!
+  - generazione di principi di co-induzione per co-induttivi
+  - ARGOMENTI IMPLICIT: li vogliamo? come? come disabilitarli localmente?
   - file elim.ma: vengono creati lambda dummy e referenziati nell'outtype di
     un case
   - tattiche e fallimenti: una tattica che non progredisce dovrebbe fallire
   - comportamento di tutte le tattiche nei confronti dei let-in
   - elim con pattern
   - 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
                ^^^^^^           ^^^^^^
@@ -54,21 +56,17 @@ TODO
     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
-
 
   GUI GRAFICA
+  - cut & paste di pattern profondi nelle ipotesi
+  - cut & paste di inner-types non chiusi non funzionanti
+  - cut & paste di congetture nello script delle prove non funzionante
   - 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
   - non semplificherebbe le cose fare in modo che matitaScript sia un widget
     (cosi' come lo e' matitaMathView) che eredita da GtkSourceView e mantiene
     internamente lo status di matita etc. Appositi segnali permetterebbero di
@@ -79,40 +77,74 @@ TODO
     ed un solo matitaScript (da spostare da un tab a un altro).
   - 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
+  - script outline, o meglio: modulo per la gestione del testo dello script
+    -> Zack
   - riattaccare hbugs (brrr...) -> Zack
 
+  - supportare l'apertura di piu' script contemporaneamente in tab/finestre
+    diversi/e
+
   GUI LOGICA
+  - -nodb non usato da disambiguazione: dopo il primo errore si ottiene
+    un errore di identificatore non trovato (dalla locate?)
+  - generazione di dipendenze verso .moo di Coq (non esistenti!) -> Zack
+  - proposta di Zack: NON calcolare (ed esportare) per default gli inner-types;
+    aggiungere un'opzione per questo a matitac (riduce drasticamente il tempo
+    di qed)
+  - la funzione alias_diff e' lentissima (anche se CSC l'ha accellerata di
+    un fattore 3x) e puo' essere evitata: chi vuole aggiungere alias (la
+    disambiguazione, il comando "alias" e l'add_obj) deve indicare
+    esplicitamente quali sono i nuovi alias, evitando cosi' la diff per
+    scoprirlo
   - matitac deve fallire quando matita vuole aggiungere un alias!
   - default equality e famiglia non e' undo-aware
+  - le coercion non sono undo-aware
   - nuovo pretty-printer testuale: non stampa usando la notazione
     (e.g. guardare output di matitac)
-  - 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
   - matitamake foo/a.ma non funziona; bisogna chiamarlo con
     matitamake /x/y/z/foo/a.ma
-  - notazione -> Luca e Zack
+  - notazione per i numeri -> Luca e Zack
   - non chiudere transitivamente i moo ?? 
-  - matitaclean all (non troglie i moo?)
 
   DEMONI E ALTRO
+  - compilare Whelp
 
 DONE
+- in MatitaEngine unificare/rimuovere eval_string, eval_from_stream e
+  eval_from_stream_greedy -> CSC
+- menu contestuale (tasto dx) nel sequent viewer -> Zack
+- in generale: invece di spiegare gli errori nel momento in cui si sollevano
+  le eccezioni, farlo quando vengono presentate all'utente. Motivo: il calcolo
+  del messaggio di errore puo' essere estremamente costoso (e' gia' successo!)
+  quando poi il messaggio non serve!!! -> CSC
+- matitaclean all (non troglie i moo?) -> Gares
+- matitaclean (e famiglia) non cancellano le directory vuote
+  (e per giunta il cicbrowser le mostra :-) -> Gares
+- missing feature unification: applicazione di teoremi (~A) quando il goal
+  e' False o di teoremi $symmetric R P$ quando il goal e' $P(x,y)$.
+  Fare un passo di delta[-beta?][-iota-etc.] quando da una parte c'e' una
+  testa rigida (che si espande in una freccia)? Ma il punto e' che il bug
+  non e' di unificazione, bensi' nella fase di preparazione del goal per
+  la apply -> CSC, Gares
+- 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! -> CSC, Gares
+- codice di inizializzazione di matita, matitac, matitatop replicato e non
+  in sync -> Gares
+- tutte gli script che parsano (e.g. matitaclean, matitadep) debbono
+  processare la notazione per evitare errori di parsing (visibili ora
+  che e' stata committata la contrib list)! -> Gares
+- E' possibile fare "Build" senza selezionare nulla, ottenendo un
+  assert false -> Gares
 - 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" ]