Jason Moxham on Sat, 27 Jun 2009 02:09:16 +0200 |
[Date Prev] [Date Next] [Thread Prev] [Thread Next] [Date Index] [Thread Index]
Re: Pari svn on MSVC |
----- Original Message ----- From: "Bill Allombert" <Bill.Allombert@math.u-bordeaux1.fr>
To: <pari-dev@list.cr.yp.to> Sent: Saturday, June 27, 2009 12:49 AM Subject: Re: Pari svn on MSVC
On Fri, Jun 26, 2009 at 10:59:28PM +0100, Jason Moxham wrote:in the file src/language/es.c in the function /* print e to S (more efficient than sprintf) */ static void str_ulong(outString *S, ulong e) { if (e == 0) str_putc(S, '0'); else { const int MAX = 21; char buf[MAX], *p = buf + MAX; *--p = 0; if (e > 9) { do *--p = "0123456789"[e % 10]; while ((e /= 10) > 9); } *--p = "0123456789"[e]; str_puts(S, p); } } char buf[MAX] is not recognized as a buffer of fixed lenght on MSVC v9.0 whereas clearly it is.Does that cause a compiler failure ? Even gcc 2.95 handles that.
yes eg jay.c is ---------- int main(void) { const int n=10; long a[n]; return 0;} ------------ cl jay.cMicrosoft (R) 32-bit C/C++ Optimizing Compiler Version 15.00.21022.08 for 80x86
Copyright (C) Microsoft Corporation. All rights reserved. jay.c jay.c(4) : error C2057: expected constant expression jay.c(4) : error C2466: cannot allocate an array of constant size 0 jay.c(4) : error C2133: 'a' : unknown size
I'm not sure what to suggest for this , perhaps a #define MAX 21 or char buf[21] ; chat *p=buf+sizeof(buf)/sizeof(buf[0]);The second seems better (because it is more localized). Cheers,Bill.