Как получить отформатированный NSString из формата и va_list? - PullRequest
10 голосов
/ 02 октября 2010

Я разрабатываю статическую библиотеку, которая будет распространяться среди других разработчиков, которым могут понадобиться операторы отладки Так что у меня есть несколько уровней ведения журнала.

Во избежание постоянного появления

if(loggingLevelCurrentlySet >= loggingLevelWantedForThisInstance){ 
     NSLog(@"log this");
}

Я создал набор оболочек для функции регистрации. Упрощенная версия выглядит так:

void myLog(int logLevel, NSString *format, va_list args){
    if((loggingLevelCurrentlySet >= logLevel)){
        NSLogv(format, args);
    }
}

void myLogLevel1(NSString *format, ...){
    va_list args;
    va_start(args, format);

    myLog(1, format, args);
    va_end(args);
}

void myLogLevel2(NSString *format, ...){
    va_list args;
    va_start(args, format);

    myLog(2, format, args);
    va_end(args);
}

и т.д.

Но теперь я хочу из myLog получить доступ к полностью отформатированной строке, чтобы сделать что-то еще.

void myLog(int logLevel, NSString *format, va_list args){
        NSString *fullString = [NSString stringWithFormat:format, args]; //crashes when args is anything but an empty list
        CFStringRef cfsr = CFStringCreateWithFormat(kCFAllocatorDefault, NULL, format, args);  //also crashes

        //want to use the string here

        if((loggingLevelCurrentlySet >= logLevel)){
            NSLogv(format, args);
        }
}

1 Ответ

13 голосов
/ 02 октября 2010
NSString *fullString = [[[NSString alloc] initWithFormat:format arguments:args] autorelease];

Для этого есть метод;)

Хотя я предлагаю не использовать функции, но некоторые простые макроопределения:

#define myLogLevel1(format, ...) myLog(1, format, __VA_ARGS__)
#define myLogLevel2(format, ...) myLog(2, format, __VA_ARGS__)
...