Hoare triple notation









up vote
2
down vote

favorite












The recent discussion of set notations re-motivates me to ask if anybody (Tej?) has a clever idea for getting Coq to accept a standard notation for Hoare triples -- something like this:



Notation " P c Q " :=
(hoare_triple P c Q)
(at level 0, P at level 99, c at level 99, Q at level 99)
: Hoare_scope.


Coq's error is "Error: A notation must include at least one symbol." Which I don't understand in light of the fact that



Notation " x " := (x) (at level 0, x at level 99).


does work.



Any advice?










share|improve this question

























    up vote
    2
    down vote

    favorite












    The recent discussion of set notations re-motivates me to ask if anybody (Tej?) has a clever idea for getting Coq to accept a standard notation for Hoare triples -- something like this:



    Notation " P c Q " :=
    (hoare_triple P c Q)
    (at level 0, P at level 99, c at level 99, Q at level 99)
    : Hoare_scope.


    Coq's error is "Error: A notation must include at least one symbol." Which I don't understand in light of the fact that



    Notation " x " := (x) (at level 0, x at level 99).


    does work.



    Any advice?










    share|improve this question























      up vote
      2
      down vote

      favorite









      up vote
      2
      down vote

      favorite











      The recent discussion of set notations re-motivates me to ask if anybody (Tej?) has a clever idea for getting Coq to accept a standard notation for Hoare triples -- something like this:



      Notation " P c Q " :=
      (hoare_triple P c Q)
      (at level 0, P at level 99, c at level 99, Q at level 99)
      : Hoare_scope.


      Coq's error is "Error: A notation must include at least one symbol." Which I don't understand in light of the fact that



      Notation " x " := (x) (at level 0, x at level 99).


      does work.



      Any advice?










      share|improve this question













      The recent discussion of set notations re-motivates me to ask if anybody (Tej?) has a clever idea for getting Coq to accept a standard notation for Hoare triples -- something like this:



      Notation " P c Q " :=
      (hoare_triple P c Q)
      (at level 0, P at level 99, c at level 99, Q at level 99)
      : Hoare_scope.


      Coq's error is "Error: A notation must include at least one symbol." Which I don't understand in light of the fact that



      Notation " x " := (x) (at level 0, x at level 99).


      does work.



      Any advice?







      coq






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 9 at 19:43









      Benjamin Pierce

      23918




      23918






















          1 Answer
          1






          active

          oldest

          votes

















          up vote
          2
          down vote



          accepted










          I'd recommend using another symbol somewhere to make this parseable. I've seen Adam Chlipala use Notation " P c Q " for example. You can also define P c Q as a printing-only notation, although I imagine that's less useful and potentially confusing to new users.



          Curly braces are special; some of the ways they're special are documented in the manual (scroll down to the third note), but I confess I don't really understand that note beyond "here be dragons, ask Hugo Herbelin".



          I can tell you mechanically why you're getting the error while " x " works:



          • curly braces don't count as symbols, because of a special remove_curly_brackets function

          • if the notation is already in the parsing table, it doesn't need to include new symbols

          This is checked in metasyntax.ml, which I found by looking for how the error message is thrown. You can also confirm what the Coq grammar is using Print Grammar constr (this is also how you figure out what level everything actually is).






          share|improve this answer




















          • Thanks -- that's super helpful. Software Foundations uses PcQ currently, and from this exchange it appears this is a local optimum. My compromise is that when I typeset them in HTML I move them closer together so they look a bit like a blackboard-bold single brace.
            – Benjamin Pierce
            Nov 10 at 0:21










          Your Answer






          StackExchange.ifUsing("editor", function ()
          StackExchange.using("externalEditor", function ()
          StackExchange.using("snippets", function ()
          StackExchange.snippets.init();
          );
          );
          , "code-snippets");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "1"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













           

          draft saved


          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53232334%2fhoare-triple-notation%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes








          up vote
          2
          down vote



          accepted










          I'd recommend using another symbol somewhere to make this parseable. I've seen Adam Chlipala use Notation " P c Q " for example. You can also define P c Q as a printing-only notation, although I imagine that's less useful and potentially confusing to new users.



          Curly braces are special; some of the ways they're special are documented in the manual (scroll down to the third note), but I confess I don't really understand that note beyond "here be dragons, ask Hugo Herbelin".



          I can tell you mechanically why you're getting the error while " x " works:



          • curly braces don't count as symbols, because of a special remove_curly_brackets function

          • if the notation is already in the parsing table, it doesn't need to include new symbols

          This is checked in metasyntax.ml, which I found by looking for how the error message is thrown. You can also confirm what the Coq grammar is using Print Grammar constr (this is also how you figure out what level everything actually is).






          share|improve this answer




















          • Thanks -- that's super helpful. Software Foundations uses PcQ currently, and from this exchange it appears this is a local optimum. My compromise is that when I typeset them in HTML I move them closer together so they look a bit like a blackboard-bold single brace.
            – Benjamin Pierce
            Nov 10 at 0:21














          up vote
          2
          down vote



          accepted










          I'd recommend using another symbol somewhere to make this parseable. I've seen Adam Chlipala use Notation " P c Q " for example. You can also define P c Q as a printing-only notation, although I imagine that's less useful and potentially confusing to new users.



          Curly braces are special; some of the ways they're special are documented in the manual (scroll down to the third note), but I confess I don't really understand that note beyond "here be dragons, ask Hugo Herbelin".



          I can tell you mechanically why you're getting the error while " x " works:



          • curly braces don't count as symbols, because of a special remove_curly_brackets function

          • if the notation is already in the parsing table, it doesn't need to include new symbols

          This is checked in metasyntax.ml, which I found by looking for how the error message is thrown. You can also confirm what the Coq grammar is using Print Grammar constr (this is also how you figure out what level everything actually is).






          share|improve this answer




















          • Thanks -- that's super helpful. Software Foundations uses PcQ currently, and from this exchange it appears this is a local optimum. My compromise is that when I typeset them in HTML I move them closer together so they look a bit like a blackboard-bold single brace.
            – Benjamin Pierce
            Nov 10 at 0:21












          up vote
          2
          down vote



          accepted







          up vote
          2
          down vote



          accepted






          I'd recommend using another symbol somewhere to make this parseable. I've seen Adam Chlipala use Notation " P c Q " for example. You can also define P c Q as a printing-only notation, although I imagine that's less useful and potentially confusing to new users.



          Curly braces are special; some of the ways they're special are documented in the manual (scroll down to the third note), but I confess I don't really understand that note beyond "here be dragons, ask Hugo Herbelin".



          I can tell you mechanically why you're getting the error while " x " works:



          • curly braces don't count as symbols, because of a special remove_curly_brackets function

          • if the notation is already in the parsing table, it doesn't need to include new symbols

          This is checked in metasyntax.ml, which I found by looking for how the error message is thrown. You can also confirm what the Coq grammar is using Print Grammar constr (this is also how you figure out what level everything actually is).






          share|improve this answer












          I'd recommend using another symbol somewhere to make this parseable. I've seen Adam Chlipala use Notation " P c Q " for example. You can also define P c Q as a printing-only notation, although I imagine that's less useful and potentially confusing to new users.



          Curly braces are special; some of the ways they're special are documented in the manual (scroll down to the third note), but I confess I don't really understand that note beyond "here be dragons, ask Hugo Herbelin".



          I can tell you mechanically why you're getting the error while " x " works:



          • curly braces don't count as symbols, because of a special remove_curly_brackets function

          • if the notation is already in the parsing table, it doesn't need to include new symbols

          This is checked in metasyntax.ml, which I found by looking for how the error message is thrown. You can also confirm what the Coq grammar is using Print Grammar constr (this is also how you figure out what level everything actually is).







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 9 at 20:59









          Tej Chajed

          2,675715




          2,675715











          • Thanks -- that's super helpful. Software Foundations uses PcQ currently, and from this exchange it appears this is a local optimum. My compromise is that when I typeset them in HTML I move them closer together so they look a bit like a blackboard-bold single brace.
            – Benjamin Pierce
            Nov 10 at 0:21
















          • Thanks -- that's super helpful. Software Foundations uses PcQ currently, and from this exchange it appears this is a local optimum. My compromise is that when I typeset them in HTML I move them closer together so they look a bit like a blackboard-bold single brace.
            – Benjamin Pierce
            Nov 10 at 0:21















          Thanks -- that's super helpful. Software Foundations uses PcQ currently, and from this exchange it appears this is a local optimum. My compromise is that when I typeset them in HTML I move them closer together so they look a bit like a blackboard-bold single brace.
          – Benjamin Pierce
          Nov 10 at 0:21




          Thanks -- that's super helpful. Software Foundations uses PcQ currently, and from this exchange it appears this is a local optimum. My compromise is that when I typeset them in HTML I move them closer together so they look a bit like a blackboard-bold single brace.
          – Benjamin Pierce
          Nov 10 at 0:21

















           

          draft saved


          draft discarded















































           


          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53232334%2fhoare-triple-notation%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Use pre created SQLite database for Android project in kotlin

          Darth Vader #20

          Ondo