[isabelle-dev] adhoc overloading: order inserting overloaded constant

Makarius makarius at sketis.net
Sat Feb 1 20:35:01 CET 2014


On Sat, 1 Feb 2014, Christian Sternagel wrote:

> So my idea was to instead use top-down rewriting (i.e., first replace 
> maximal subterms that fit a given pattern). This is what 
> "Pattern.rewrite_term_top" does, right? So after replacing 
> "rewrite_term" by "rewrite_term_top", I get the expected results.
>
> Now my question. Can anybody think of a reason why "rewrite_term_top" 
> would not be generally preferable over "rewrite_term" inside of 
> "insert_overloaded"?

This is an old story.  Printing usually works better top-down, e.g. see 
good old 'translations' with their yo-yo strategy.  When 'abbreviation' 
was introduced, there was Pattern.rewrite_term, but not 
Pattern.rewrite_term_top yet, so there was no other way.

I kept telling Stefan Berghofer about that omission until he made an 
laternative version in 2010: see 6e45e4c94751, 5d2fe4e09354 (with typical 
tell-nothing log entries).

So in analogy, the same will probably work for adhoc_overloading as well, 
without going through all the reasoning again.


> If not, could one of the devs incorporate this tiny change please?

OK, I will try this out.


 	Makarius



More information about the isabelle-dev mailing list