[devel] Re: Q: snprintf

Alexey Tourbin =?iso-8859-1?q?at_=CE=C1_altlinux=2Eru?=
Вт Мар 23 03:01:21 MSK 2004


On Mon, Mar 22, 2004 at 06:24:50PM +0200, Alexander Bokovoy wrote:
> > > --- src/lvm.c.orig     2004-01-13 11:37:53.000000000 -0200
> > > +++ src/lvm.c  2004-01-13 11:33:34.000000000 -0200
> > > @@ -32,7 +32,7 @@
> > > 
> > >  /* function to convert a lua_Number to a string */
> > >  #ifndef lua_number2str
> > > -#define lua_number2str(s,n)     sprintf((s), LUA_NUMBER_FMT, (n))
> > > +#define lua_number2str(s,n)     snprintf((s), sizeof((s)), LUA_NUMBER_FMT, (n))
> > >  #endif
> > > 
> > 
> > Т.е. есть кусок некоторого API, которое broken by design, но его
> > кому-то хочется зафиксить.  Но в данном случае использование sizeof
> > в макросе некорректно, т.к. переменная s может быть указателем, а не
> > именем массива, а размер любого указателя всегда равен sizeof(long).
> > 
> > Пока приходит в голову только следующее:
> > 
> > #define lua_number2str(s,n)	(sizeof(s) > sizeof(char*)) ? \
> > 	snprintf((s), sizeof((s)), LUA_NUMBER_FMT, (n)) : \
> > 	sprintf((s), LUA_NUMBER_FMT, (n))
> Криво, честно говоря. Но в целом, наверное, сойдет.

На самом деле это не часть API. :)
Так что достаточно проверить src/lvm.c.

В целом же, обобщенный оператор sizeof() должен быть RTTI функцией,
которая умеет залезать в структуры malloc().  Мечтать не вредно...
----------- следующая часть -----------
Было удалено вложение не в текстовом формате...
Имя     : =?iso-8859-1?q?=CF=D4=D3=D5=D4=D3=D4=D7=D5=C5=D4?=
Тип     : application/pgp-signature
Размер  : 189 байтов
Описание: =?iso-8859-1?q?=CF=D4=D3=D5=D4=D3=D4=D7=D5=C5=D4?=
Url     : <http://lists.altlinux.org/pipermail/devel/attachments/20040323/f39dd2d7/attachment-0001.bin>


Подробная информация о списке рассылки Devel