TODO.md
author wenzelm
Tue, 17 Aug 2021 22:39:48 +0200
changeset 60382 3e3480647439
parent 60379 39c5bbc97346
child 60400 2d97d160a183
permissions -rw-r--r--
less TODO;
wenzelm@60234
     1
* MW: check uses of Unsynchronized.ref vs. Synchronized.var;
wenzelm@60234
     2
wenzelm@60216
     3
* MW: clarify/eliminate Isabelle/Scala add-ons (presently unused)
wenzelm@60216
     4
wenzelm@60216
     5
    diff -r /home/makarius/isabelle/repos-Isabelle2021/src/Pure/build-jars ./src/Pure/build-jars
wenzelm@60216
     6
    11a12
wenzelm@60216
     7
    >   src/Tools/isac/BridgeJEdit/isac.scala
wenzelm@60216
     8
wenzelm@60216
     9
    diff -r /home/makarius/isabelle/repos-Isabelle2021/src/Pure/Tools/scala_project.scala ./src/Pure/Tools/scala_project.scala
wenzelm@60216
    10
    76a77
wenzelm@60216
    11
    >       "src/Tools/isac/etc" -> Path.explode("isabelle.isac"),
wenzelm@60225
    12
wenzelm@60316
    13
* Eliminate Thy_Info.get_theory eventually: should take theory from ancestory
walther@60363
    14
  within current context.
walther@60362
    15
    cf. e587c45cae0f note in Build_Thydata.thy
wenzelm@60316
    16
wenzelm@60295
    17
* Clarify symmetric rule: Thm.apply_attribute Calculation.symmetric thm context (!?);
walther@60369
    18
    ??
wenzelm@60295
    19
wenzelm@60316
    20
* KEStore_Elems: Should we eliminate union_overwrite and use standard namespace merge?
wenzelm@60316
    21
  (Exception: rlss with its special cross-theory merge.)
walther@60376
    22
    ? how adapt the different signatures ?
walther@60376
    23
    union_overwrite: ('a * 'a -> bool) -> 'a list -> 'a list -> 'a list
walther@60376
    24
    merge          : ('a * 'a -> bool) -> 'a list * 'a list -> 'a list
wenzelm@60285
    25
wenzelm@60281
    26
* What is the purpose of "#numeral" instead of plain numeral?
walther@60368
    27
    ??
wenzelm@60281
    28
wenzelm@60281
    29
* Check/clarify Context.theory_name vs. Context.theory_long_name.
walther@60369
    30
    present ISAC assumes 2 sessions in the MathEngine, Specify and Interpret, 
walther@60369
    31
    and all Isac_Knowledge is in session Isac.
walther@60369
    32
    So Context.theory_name suffices
wenzelm@60281
    33
wenzelm@60292
    34
* Eliminate mutable Rewrite_Ord.rew_ord' (!?);
walther@60362
    35
    shall be done in connection with cf. e587c45cae0f note in Build_Thydata.thy
wenzelm@60292
    36
wenzelm@60315
    37
* What is the idea behind KEStore_Elems.add_thes? How to do it properly in current Isabelle?
walther@60365
    38
    https://static.miraheze.org/isacwiki/0/04/Isac-docu.pdf distinguishes 
walther@60365
    39
    several kinds of ISAC users, in particular "math author (Mathematik-Autor)" and
walther@60365
    40
    "course designer (Kurs-Designer)". The latter just adds examples which re-use existing
walther@60365
    41
    knowledge designed by the former. KEStore_Elems.add_thes is an interface for the latter.   
wenzelm@60315
    42
wenzelm@60311
    43
* WN: proper ML antiquotations for "Tactical.Try" etc. --- be careful about unclear situations,
wenzelm@60311
    44
  e.g. "Tactical.Try" vs. "Lucas_Interpreter.Try";
wenzelm@60311
    45
walther@60376
    46
* WN: Avoid Thm.get_name_hint and use Global_Theory.get_thm instead, get theory from References.T
walther@60370
    47
    and push theory through as argument of respective functions.
wenzelm@60304
    48
wenzelm@60241
    49
* WN: more direct logical foundations wrt. Isabelle/HOL, eliminate many axiomatizations
wenzelm@60241
    50
    - quite often "axiomatization ..." can be turned into "lemma ... by auto"
wenzelm@60241
    51
      without further ado;
wenzelm@60241
    52
    - sometimes this requires to use more specific types / type classes;
wenzelm@60241
    53
    - sometimes this requires to use proper definitional mechanisms (e.g. 'primrec', 'fun');
wenzelm@60241
    54
    - a few "hard" cases will remain, to be reconsidered eventually (e.g. differentiation);
wenzelm@60234
    55
walther@60378
    56
* WN: eliminate ThmC.numerals_to_Free, check tests marked TOODOO.1
walther@60357
    57
  + ? how do algebraic operations on numerals ? Presburger ? simplifier ? hack see
walther@60357
    58
    https://hg.risc.uni-linz.ac.at/wneuper/isa/file/a14022b99b92/src/Tools/isac/ProgLang/evaluate.sml#l210
walther@60245
    59
wenzelm@60247
    60
* WN: "fun pr_ord" is not required if used with @{make_string}, @{print}, @{print tracing};
walther@60375
    61
    takes only static arguments ----------------^^^^^^^^^^^^^^, not value of "hd_ord (f, g)"
walther@60375
    62
    ? are there better approximations to old output of (*1*) than with (*2*)
walther@60375
    63
    (*1*)val _ = tracing ("hd_ord (f, g)      = " ^ ((pr_ord o hd_ord) (f, g)) );
walther@60375
    64
    (*2*)val _ = @{print tracing}{a = "hd_ord (f, g)      = ", z = hd_ord (f, g)}(**)
walther@60317
    65
walther@60317
    66
* WN: reduce the number of TermC.parse*;
walther@60340
    67
  + 0d22a6bf1fc6 was too much for 1 changeset
walther@60340
    68
  + first parse with ctxt in Specify (O_Model.init shall return a context,..) etc
wenzelm@60379
    69
wenzelm@60379
    70
wenzelm@60379
    71
* WN: eliminate global flags like "trace_on", replace Unsynchronized.ref by
wenzelm@60379
    72
wenzelm@60379
    73
ML \<open>
wenzelm@60379
    74
  val rewrite_trace = Attrib.setup_config_bool \<^binding>\<open>rewrite_trace\<close> (K false);
wenzelm@60379
    75
\<close>