ntg-context - mailing list for ConTeXt users
 help / color / mirror / Atom feed
From: Mojca Miklavec <mojca.miklavec.lists@gmail.com>
To: mailing list for ConTeXt users <ntg-context@ntg.nl>
Subject: Re: unusual behaviour of \if(x)
Date: Wed, 1 Jun 2011 15:52:21 +0200	[thread overview]
Message-ID: <BANLkTi==B0TNvWABV+kNShhEu1aca0=NbQ@mail.gmail.com> (raw)
In-Reply-To: <5E0002C6-DFC0-4069-8134-CEBBE0BED41D@googlemail.com>

On Wed, Jun 1, 2011 at 15:36, Wolfgang Schuster wrote:
>
> Am 01.06.2011 um 15:26 schrieb Mojca Miklavec:
>
>> Dear magitians,
>>
>> I discovered this in LaTeX, but ConTeXt behaves the same (plain TeX
>> behaves differently). Can somebody please explain me why this code
>> fails to work? (A workaround is to move \newif on top which I'm
>> willing to do, but I'm still curious.)
>>
>> \starttext
>>
>> \ifx\hbox\undefined
>>  \message{invisible to tex}
>>  \newif\ifabc \abcfalse
>>  \ifabc \message{abc true breaks} \else \message{abc false breaks} \fi
>> \fi
>>
>> \stoptext
>>
>>
>> systems         : begin file iftest at line 1
>> abc false breaks
>> ! Extra \fi.
>> l.7 \fi
>
> The \ifx ends with the first \fi

I figured that out, but I still find it very weird.

> from \ifabc which isn’t defined and
> ignored by TeX

This part somehow makes sense (TeX should not keep defining stuff and
writing out stuff) ...

> the last \fi is left which generates the error message

The code works when using \ifx\hboxx\undefined ... But despite the
explanation, this is very very very weird. Or to quote Taco: "The
trick of TeX being bug-free is that all the bugs and limitations are
documented." I hope that this behaviour is documented in TeXbook.

To some extent this resembles
/* I want to comment out this code
   c = a + b;
   /* a more complex equation */
   c = a * b;
*/
but it is not quite the same.

Mojca
___________________________________________________________________________________
If your question is of interest to others as well, please add an entry to the Wiki!

maillist : ntg-context@ntg.nl / http://www.ntg.nl/mailman/listinfo/ntg-context
webpage  : http://www.pragma-ade.nl / http://tex.aanhet.net
archive  : http://foundry.supelec.fr/projects/contextrev/
wiki     : http://contextgarden.net
___________________________________________________________________________________

  reply	other threads:[~2011-06-01 13:52 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-06-01 13:26 Mojca Miklavec
2011-06-01 13:36 ` Wolfgang Schuster
2011-06-01 13:52   ` Mojca Miklavec [this message]
2011-06-01 14:08     ` Hans Hagen
2011-06-01 14:10     ` luigi scarso
2011-06-01 13:46 ` luigi scarso
2011-06-01 13:56   ` Hans Hagen
2011-06-01 14:01     ` luigi scarso
2011-06-01 14:09       ` Wolfgang Schuster

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='BANLkTi==B0TNvWABV+kNShhEu1aca0=NbQ@mail.gmail.com' \
    --to=mojca.miklavec.lists@gmail.com \
    --cc=ntg-context@ntg.nl \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).