- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
// укорочено для краткости.
void ATraceClass::LogFunction(const char *format, va_list ap)
{
/* ... declarations ... */
for (p=format; (*p)&&(!isTruncated); p++)
{
if ( * p == '%' )
switch( * ++p )
{
case 'c':
{ /* ... */ }
break;
case 'd':
case 'i':
{ /* ... */ }
break;
case 'l': // это %ld
{ /* ... */ }
break;
case 'L': // это %Ld
{ /* ... */ }
break;
case 'f': // a это %g
{ /* ... */ }
break;
case 'F': // a это %Lg
{ /* ... */ }
break;
case 's':
{ /* ... */ }
break;
default: // this is an ERROR case, but we will not perform coding at this point ... maybe later
break;
}
else {
/* ... */
}
}
}
наболело. одно чудило (с большой букмы Му) наговнокодило это дело под эгидой "stdio это С, мы в С++ можем круче!!!" ну с тех пор и переизобретают велосипед - с квадратными колёсами. даже %% не догадались сделать.
уже как года два давлю вот это Г, но наши немецкие умельцы копи-пастят это в новые модуля быстрее чем я успеваю это удалять.
самое гадкое что народ пишет код как обычно ожидая стандартные stdio шорткаты, и потом долго гадает куда блин сообщение подевалось.
Webkill 01.06.2010 01:44 # 0
TOPT 23.03.2018 14:29 # 0
SemaReal 24.03.2018 03:53 # 0
subaru 24.03.2018 20:00 # 0
SemaReal 24.03.2018 20:12 # 0