220 32569 <d14bfe0d-8c72-49a0-bf08-8041998dd125@isocpp.org> article
Path: news.gmane.org!.POSTED!not-for-mail
From: ma.kalbfuss@web.de
Newsgroups: gmane.comp.lang.c++.isocpp.proposals
Subject: Re: relaxing rules for ternary operator. Allow
 incompatible types.
Date: Sun, 21 May 2017 23:33:32 -0700 (PDT)
Lines: 346
Approved: news@gmane.org
Message-ID: <d14bfe0d-8c72-49a0-bf08-8041998dd125@isocpp.org>
References: <1b5ee8eb-53df-4e98-af2f-829c7bc2e5b2@isocpp.org> <1678895.0nQhqNqFQE@tjmaciei-mobl1> <b75d4532-bb6e-4b66-8f9b-a2a94b679e96@isocpp.org>
 <1620864.HL4j5jKv18@tjmaciei-mobl1>
Reply-To: std-proposals@isocpp.org
NNTP-Posting-Host: blaine.gmane.org
Mime-Version: 1.0
Content-Type: multipart/mixed; 
	boundary="----=_Part_2490_786802544.1495434812839"
X-Trace: blaine.gmane.org 1495434816 15477 195.159.176.226 (22 May 2017 06:33:36 GMT)
X-Complaints-To: usenet@blaine.gmane.org
NNTP-Posting-Date: Mon, 22 May 2017 06:33:36 +0000 (UTC)
To: ISO C++ Standard - Future Proposals <std-proposals@isocpp.org>
Original-X-From: std-proposals+bncBC7YTI72XQOBBPMMRLEQKGQEVRXM4RI@isocpp.org Mon May 22 08:33:29 2017
Return-path: <std-proposals+bncBC7YTI72XQOBBPMMRLEQKGQEVRXM4RI@isocpp.org>
Envelope-to: gclcip-std-proposals@m.gmane.org
Original-Received: from mail-pf0-f197.google.com ([209.85.192.197])
	by blaine.gmane.org with esmtp (Exim 4.84_2)
	(envelope-from <std-proposals+bncBC7YTI72XQOBBPMMRLEQKGQEVRXM4RI@isocpp.org>)
	id 1dCguH-0003tX-9O
	for gclcip-std-proposals@m.gmane.org; Mon, 22 May 2017 08:33:29 +0200
Original-Received: by mail-pf0-f197.google.com with SMTP id c10sf117000384pfg.10
        for <gclcip-std-proposals@m.gmane.org>; Sun, 21 May 2017 23:33:35 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
        d=isocpp-org.20150623.gappssmtp.com; s=20150623;
        h=date:from:to:message-id:in-reply-to:references:subject:mime-version
         :x-original-sender:reply-to:precedence:mailing-list:list-id
         :x-spam-checked-in-group:list-post:list-help:list-archive
         :list-subscribe:list-unsubscribe;
        bh=JQnXfmME4D3mH2n2VWSrR2iQV5m4ZljG9zuNMwkDYYk=;
        b=ASjeKAwKvmlic8G052/P9pV8975LqJgihdZYEK0QpelIni9kskzlfgfqN7kPHnMeaM
         yw9BeQjbRdtjo14mwH+vwWf1TUX/TxxG984lmWyZ5v3zDX6SydlmM5JiuCQUhS5Rrrql
         3vk4FTeoNR8vyp3Ml7EIbQSQZF2O03dl/fvj/GRZPP9ofvTgeICYNuwhjVQwwscSIZJT
         swmWYqWbBRFcQoK7AJVT5c5IXU0R2n0Ym56TmQS446nsajTffil0+zynsE3mhlIGBnoV
         Y16TNWM8tqWR7qXzzeXu2Z65kRDOy6DUO9UT4z/+sGBtyCCKP67ehfugN6++prjpQXiY
         sQMQ==
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
        d=1e100.net; s=20161025;
        h=x-gm-message-state:date:from:to:message-id:in-reply-to:references
         :subject:mime-version:x-original-sender:reply-to:precedence
         :mailing-list:list-id:x-spam-checked-in-group:list-post:list-help
         :list-archive:list-subscribe:list-unsubscribe;
        bh=JQnXfmME4D3mH2n2VWSrR2iQV5m4ZljG9zuNMwkDYYk=;
        b=T1CQp3BE2NmLY0dH4c6wBiIjA3I907DTDskko+nubgDBIgpw5iCiiFyxRs2zSfkrep
         tuSfB1qMKAZeCoBhc6edo8q0MtYULYNiI1NTuX6lkVlG3254FrOlu/0GKksEk8Ps7YIK
         I3u+9WxoY/paugTFSa6wMN3h/AOdkXSsYjRTo4bnaOfTQoOWkeTEmsc3/U2UfQpWFpcK
         KWRUVfQpPuBM2BTF2btj4RW1HY1c4hk4Tcb5d7cuYW3D9buQG2mWdXoDGPRYCQA6Med0
         WrHTE4M6ml7oVsQyXtF4gMTp4dkGYmbtGiR2DQDLcXqsZ1RwRROcU1vmWyYCF23QLIgV
         sMUA==
X-Gm-Message-State: AODbwcBgxtPKLI8wGZvsYAn2Ad0uqjWoa0Z7wSZ6HXDlpEhtHBJvyj3g
	8eTdhGX5fdj7W+0t
X-Received: by 10.99.175.15 with SMTP id w15mr9974769pge.67.1495434814504;
        Sun, 21 May 2017 23:33:34 -0700 (PDT)
X-BeenThere: std-proposals@isocpp.org
Original-Received: by 10.157.9.241 with SMTP id 46ls3010467otz.6.gmail; Sun, 21 May
 2017 23:33:33 -0700 (PDT)
X-Received: by 10.157.80.33 with SMTP id a33mr450248oth.13.1495434813541;
        Sun, 21 May 2017 23:33:33 -0700 (PDT)
In-Reply-To: <1620864.HL4j5jKv18@tjmaciei-mobl1>
X-Original-Sender: ma.kalbfuss@web.de
Precedence: list
Mailing-list: list std-proposals@isocpp.org; contact std-proposals+owners@isocpp.org
List-ID: <std-proposals.isocpp.org>
X-Google-Group-Id: 399137483710
List-Post: <https://groups.google.com/a/isocpp.org/group/std-proposals/post>, <mailto:std-proposals@isocpp.org>
List-Help: <https://support.google.com/a/isocpp.org/bin/topic.py?topic=25838>, <mailto:std-proposals+help@isocpp.org>
List-Archive: <https://groups.google.com/a/isocpp.org/group/std-proposals/>
List-Subscribe: <https://groups.google.com/a/isocpp.org/group/std-proposals/subscribe>,
 <mailto:std-proposals+subscribe@isocpp.org>
List-Unsubscribe: <mailto:googlegroups-manage+399137483710+unsubscribe@googlegroups.com>,
 <https://groups.google.com/a/isocpp.org/group/std-proposals/subscribe>
Xref: news.gmane.org gmane.comp.lang.c++.isocpp.proposals:32569
Archived-At: <http://permalink.gmane.org/gmane.comp.lang.c++.isocpp.proposals/32569>

------=_Part_2490_786802544.1495434812839
Content-Type: multipart/alternative; 
	boundary="----=_Part_2491_1041723913.1495434812839"

------=_Part_2491_1041723913.1495434812839
Content-Type: text/plain; charset="UTF-8"

Sure, you don't have always exponential growth when using templates. But if 
you simulating this case with template functions you end up having the same 
problem.
So I wouldn't say, that this something completely new. It is the nature of 
the problem we try to solve. You have either runtime overhad or exponential 
growth.
Maybe there is a way to avoid exponential growth using optimization 
techniques. Assumably in many cases the optimizer will reduce the amount of 
code anyway.
There could be a guaranteed optimization. But I'm not sure which. I will 
build up an example, where the code isn't completely optimized away.

I assume variant is an untagged union? Let's try to minimise our examples.


Am Montag, 22. Mai 2017 02:12:20 UTC+2 schrieb Thiago Macieira:
>
> On domingo, 21 de maio de 2017 13:54:51 PDT ma.ka...@web.de <javascript:> 
> wrote: 
> > Yeah, i realize that. This is something you have to consider if you're 
> > using templates extensively. 
>
> No, it isn't. Today, the use of templates does not imply exponential 
> growth of 
> generated code. 
>
> That is something completely new with your proposal. 
>
> > This is not the right solution for everything. 
> > I think in most cases, you use one or at most two ternary operators in 
> one 
> > place. For three or more ternary operators the runtime overhead is 
> > assumably the lesser of two evils. But even if it grows exponentially, 
> the 
> > constants are pretty small. Normaly only a few instructions are 
> involved. 
>
> Not necessarily. Remember that you may not reevaluate the condition, so 
> either 
> this generates completely separate code paths (and thus the exponential 
> expansion) or the result of the evaluation is stored in a hidden variable 
> that 
> is evaluated every time you access that automatic variable. 
>
> That is, when you write: 
>
>         auto x = runtime_condition1 ? A{} : B{}; 
>         auto y = runtime_conditoin2 ? C{} : D{}; 
>         x.f(); 
>
> This expands to either: 
>
>         if (runtime_condition1) { 
>                 auto x = A{}; 
>                 if (runtime_condition2) { 
>                         auto y = C {}; 
>                         x.f() + y.f(); 
>                 } else { 
>                         auto y = D {}; 
>                         x.f() + y.f(); 
>                 } 
>         } else { 
>                 auto x = B{}; 
>                 if (runtime_condition2) { 
>                         auto y = C {}; 
>                         x.f() + y.f(); 
>                 } else { 
>                         auto y = D {}; 
>                         x.f() + y.f(); 
>                 } 
>         } 
>
> or to: 
>
>         variant<A, B> x; 
>         variant<C, D> y; 
>         bool hidden1 = runtime_condition1; 
>         if (hidden1) 
>                 x.create<A>(); 
>         else 
>                 x.create<B>(); 
>         bool hidden2 = runtime_condition2; 
>         if (hidden2) 
>                 y.create<C>(); 
>         else 
>                 y.create<D>(); 
>         if (hidden1) { 
>                 if (hidden2) 
>                         x.as<A>().f() + y.as<C>().f(); 
>                 else 
>                         x.as<A>().f() + y.as<D>().f(); 
>         } else { 
>                 if (hidden2) 
>                         x.as<B>().f() + y.as<C>().f(); 
>                 else 
>                         x.as<B>().f() + y.as<D>().f(); 
>         } 
>
> -- 
> Thiago Macieira - thiago (AT) macieira.info - thiago (AT) kde.org 
>    Software Architect - Intel Open Source Technology Center 
>
>

-- 
You received this message because you are subscribed to the Google Groups "ISO C++ Standard - Future Proposals" group.
To unsubscribe from this group and stop receiving emails from it, send an email to std-proposals+unsubscribe@isocpp.org.
To post to this group, send email to std-proposals@isocpp.org.
To view this discussion on the web visit https://groups.google.com/a/isocpp.org/d/msgid/std-proposals/d14bfe0d-8c72-49a0-bf08-8041998dd125%40isocpp.org.

------=_Part_2491_1041723913.1495434812839
Content-Type: text/html; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable

<div dir=3D"ltr">Sure, you don&#39;t have always exponential growth when us=
ing templates. But if you simulating this case with template functions you =
end up having the same problem.<br>So I wouldn&#39;t say, that this somethi=
ng completely new. It is the nature of the problem we try to solve. You hav=
e either runtime overhad or exponential growth.<br>Maybe there is a way to =
avoid exponential growth using optimization techniques. Assumably in many c=
ases the optimizer will reduce the amount of code anyway.<br>There could be=
 a guaranteed optimization. But I&#39;m not sure which. I will build up an =
example, where the code isn&#39;t completely optimized away.<br><br>I assum=
e variant is an untagged union? Let&#39;s try to minimise our examples.<br>=
<br><br>Am Montag, 22. Mai 2017 02:12:20 UTC+2 schrieb Thiago Macieira:<blo=
ckquote class=3D"gmail_quote" style=3D"margin: 0;margin-left: 0.8ex;border-=
left: 1px #ccc solid;padding-left: 1ex;">On domingo, 21 de maio de 2017 13:=
54:51 PDT <a href=3D"javascript:" target=3D"_blank" gdf-obfuscated-mailto=
=3D"u-14zLSRAwAJ" rel=3D"nofollow" onmousedown=3D"this.href=3D&#39;javascri=
pt:&#39;;return true;" onclick=3D"this.href=3D&#39;javascript:&#39;;return =
true;">ma.ka...@web.de</a> wrote:
<br>&gt; Yeah, i realize that. This is something you have to consider if yo=
u&#39;re
<br>&gt; using templates extensively.=20
<br>
<br>No, it isn&#39;t. Today, the use of templates does not imply exponentia=
l growth of=20
<br>generated code.
<br>
<br>That is something completely new with your proposal.
<br>
<br>&gt; This is not the right solution for everything.
<br>&gt; I think in most cases, you use one or at most two ternary operator=
s in one
<br>&gt; place. For three or more ternary operators the runtime overhead is
<br>&gt; assumably the lesser of two evils. But even if it grows exponentia=
lly, the
<br>&gt; constants are pretty small. Normaly only a few instructions are in=
volved.
<br>
<br>Not necessarily. Remember that you may not reevaluate the condition, so=
 either=20
<br>this generates completely separate code paths (and thus the exponential=
=20
<br>expansion) or the result of the evaluation is stored in a hidden variab=
le that=20
<br>is evaluated every time you access that automatic variable.=20
<br>
<br>That is, when you write:
<br>
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0auto x =3D runtime_cond=
ition1 ? A{} : B{};=20
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0auto y =3D runtime_cond=
itoin2 ? C{} : D{};
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0x.f();
<br>
<br>This expands to either:
<br>
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0if (runtime_condition1)=
 {
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0auto x =3D A{};
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0if (runtime_condition2) {
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
auto y =3D C {};
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
x.f() + y.f();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0} else {
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
auto y =3D D {};
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
x.f() + y.f();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0}
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0} else {
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0auto x =3D B{};
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0if (runtime_condition2) {
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
auto y =3D C {};
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
x.f() + y.f();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0} else {
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
auto y =3D D {};
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
x.f() + y.f();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0}
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0}
<br>
<br>or to:
<br>
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0variant&lt;A, B&gt; x;
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0variant&lt;C, D&gt; y;
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0bool hidden1 =3D runtim=
e_condition1;
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0if (hidden1)
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0x.create&lt;A&gt;();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0else
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0x.create&lt;B&gt;();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0bool hidden2 =3D runtim=
e_condition2;
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0if (hidden2)
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0y.create&lt;C&gt;();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0else
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0y.create&lt;D&gt;();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0if (hidden1) {
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0if (hidden2)
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
<a href=3D"http://x.as" target=3D"_blank" rel=3D"nofollow" onmousedown=3D"t=
his.href=3D&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2Fx.as\x26sa\x3dD=
\x26sntz\x3d1\x26usg\x3dAFQjCNF_RgZBHEjoHC6BbryEAu7_i-OuOg&#39;;return true=
;" onclick=3D"this.href=3D&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2F=
x.as\x26sa\x3dD\x26sntz\x3d1\x26usg\x3dAFQjCNF_RgZBHEjoHC6BbryEAu7_i-OuOg&#=
39;;return true;">x.as</a>&lt;<wbr>A&gt;().f() + <a href=3D"http://y.as" ta=
rget=3D"_blank" rel=3D"nofollow" onmousedown=3D"this.href=3D&#39;http://www=
..google.com/url?q\x3dhttp%3A%2F%2Fy.as\x26sa\x3dD\x26sntz\x3d1\x26usg\x3dAF=
QjCNEuQstsnF5olzl8yADHUQunU-gAnw&#39;;return true;" onclick=3D"this.href=3D=
&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2Fy.as\x26sa\x3dD\x26sntz\x3=
d1\x26usg\x3dAFQjCNEuQstsnF5olzl8yADHUQunU-gAnw&#39;;return true;">y.as</a>=
&lt;C&gt;().f();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0else
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
<a href=3D"http://x.as" target=3D"_blank" rel=3D"nofollow" onmousedown=3D"t=
his.href=3D&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2Fx.as\x26sa\x3dD=
\x26sntz\x3d1\x26usg\x3dAFQjCNF_RgZBHEjoHC6BbryEAu7_i-OuOg&#39;;return true=
;" onclick=3D"this.href=3D&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2F=
x.as\x26sa\x3dD\x26sntz\x3d1\x26usg\x3dAFQjCNF_RgZBHEjoHC6BbryEAu7_i-OuOg&#=
39;;return true;">x.as</a>&lt;<wbr>A&gt;().f() + <a href=3D"http://y.as" ta=
rget=3D"_blank" rel=3D"nofollow" onmousedown=3D"this.href=3D&#39;http://www=
..google.com/url?q\x3dhttp%3A%2F%2Fy.as\x26sa\x3dD\x26sntz\x3d1\x26usg\x3dAF=
QjCNEuQstsnF5olzl8yADHUQunU-gAnw&#39;;return true;" onclick=3D"this.href=3D=
&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2Fy.as\x26sa\x3dD\x26sntz\x3=
d1\x26usg\x3dAFQjCNEuQstsnF5olzl8yADHUQunU-gAnw&#39;;return true;">y.as</a>=
&lt;D&gt;().f();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0} else {
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0if (hidden2)
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
<a href=3D"http://x.as" target=3D"_blank" rel=3D"nofollow" onmousedown=3D"t=
his.href=3D&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2Fx.as\x26sa\x3dD=
\x26sntz\x3d1\x26usg\x3dAFQjCNF_RgZBHEjoHC6BbryEAu7_i-OuOg&#39;;return true=
;" onclick=3D"this.href=3D&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2F=
x.as\x26sa\x3dD\x26sntz\x3d1\x26usg\x3dAFQjCNF_RgZBHEjoHC6BbryEAu7_i-OuOg&#=
39;;return true;">x.as</a>&lt;<wbr>B&gt;().f() + <a href=3D"http://y.as" ta=
rget=3D"_blank" rel=3D"nofollow" onmousedown=3D"this.href=3D&#39;http://www=
..google.com/url?q\x3dhttp%3A%2F%2Fy.as\x26sa\x3dD\x26sntz\x3d1\x26usg\x3dAF=
QjCNEuQstsnF5olzl8yADHUQunU-gAnw&#39;;return true;" onclick=3D"this.href=3D=
&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2Fy.as\x26sa\x3dD\x26sntz\x3=
d1\x26usg\x3dAFQjCNEuQstsnF5olzl8yADHUQunU-gAnw&#39;;return true;">y.as</a>=
&lt;C&gt;().f();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0else
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=
=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=
<a href=3D"http://x.as" target=3D"_blank" rel=3D"nofollow" onmousedown=3D"t=
his.href=3D&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2Fx.as\x26sa\x3dD=
\x26sntz\x3d1\x26usg\x3dAFQjCNF_RgZBHEjoHC6BbryEAu7_i-OuOg&#39;;return true=
;" onclick=3D"this.href=3D&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2F=
x.as\x26sa\x3dD\x26sntz\x3d1\x26usg\x3dAFQjCNF_RgZBHEjoHC6BbryEAu7_i-OuOg&#=
39;;return true;">x.as</a>&lt;<wbr>B&gt;().f() + <a href=3D"http://y.as" ta=
rget=3D"_blank" rel=3D"nofollow" onmousedown=3D"this.href=3D&#39;http://www=
..google.com/url?q\x3dhttp%3A%2F%2Fy.as\x26sa\x3dD\x26sntz\x3d1\x26usg\x3dAF=
QjCNEuQstsnF5olzl8yADHUQunU-gAnw&#39;;return true;" onclick=3D"this.href=3D=
&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2Fy.as\x26sa\x3dD\x26sntz\x3=
d1\x26usg\x3dAFQjCNEuQstsnF5olzl8yADHUQunU-gAnw&#39;;return true;">y.as</a>=
&lt;D&gt;().f();
<br>=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0}
<br>
<br>--=20
<br>Thiago Macieira - thiago (AT) <a href=3D"http://macieira.info" target=
=3D"_blank" rel=3D"nofollow" onmousedown=3D"this.href=3D&#39;http://www.goo=
gle.com/url?q\x3dhttp%3A%2F%2Fmacieira.info\x26sa\x3dD\x26sntz\x3d1\x26usg\=
x3dAFQjCNEswDUBNCNanbu7euhqLn_62FW8ag&#39;;return true;" onclick=3D"this.hr=
ef=3D&#39;http://www.google.com/url?q\x3dhttp%3A%2F%2Fmacieira.info\x26sa\x=
3dD\x26sntz\x3d1\x26usg\x3dAFQjCNEswDUBNCNanbu7euhqLn_62FW8ag&#39;;return t=
rue;">macieira.info</a> - thiago (AT) <a href=3D"http://kde.org" target=3D"=
_blank" rel=3D"nofollow" onmousedown=3D"this.href=3D&#39;http://www.google.=
com/url?q\x3dhttp%3A%2F%2Fkde.org\x26sa\x3dD\x26sntz\x3d1\x26usg\x3dAFQjCNH=
GRJdo5_JYG1DowztwAHAKs80XSA&#39;;return true;" onclick=3D"this.href=3D&#39;=
http://www.google.com/url?q\x3dhttp%3A%2F%2Fkde.org\x26sa\x3dD\x26sntz\x3d1=
\x26usg\x3dAFQjCNHGRJdo5_JYG1DowztwAHAKs80XSA&#39;;return true;">kde.org</a=
>
<br>=C2=A0 =C2=A0Software Architect - Intel Open Source Technology Center
<br>
<br></blockquote></div>

<p></p>

-- <br />
You received this message because you are subscribed to the Google Groups &=
quot;ISO C++ Standard - Future Proposals&quot; group.<br />
To unsubscribe from this group and stop receiving emails from it, send an e=
mail to <a href=3D"mailto:std-proposals+unsubscribe@isocpp.org">std-proposa=
ls+unsubscribe@isocpp.org</a>.<br />
To post to this group, send email to <a href=3D"mailto:std-proposals@isocpp=
..org">std-proposals@isocpp.org</a>.<br />
To view this discussion on the web visit <a href=3D"https://groups.google.c=
om/a/isocpp.org/d/msgid/std-proposals/d14bfe0d-8c72-49a0-bf08-8041998dd125%=
40isocpp.org?utm_medium=3Demail&utm_source=3Dfooter">https://groups.google.=
com/a/isocpp.org/d/msgid/std-proposals/d14bfe0d-8c72-49a0-bf08-8041998dd125=
%40isocpp.org</a>.<br />

------=_Part_2491_1041723913.1495434812839--

------=_Part_2490_786802544.1495434812839--

.
