开发者

Managing several hundred occurrences of NSLocalizedString

开发者 https://www.devze.com 2022-12-25 15:47 出处:网络
My application has several hundred points of localisation, some of which can be reused many times. To prevent from hunting and pecking through code to find occurrences of a particular NSLocalizedStrin

My application has several hundred points of localisation, some of which can be reused many times. To prevent from hunting and pecking through code to find occurrences of a particular NSLocalizedString, I create a macro for each in a header file using the #define preprocessor directive. For example:

#define kLocFirstString  NSLocalizedString(@"Default Text", @"Comment")
#de开发者_开发技巧fine kLocSecondString NSLocalizedString(@"More Text", @"Another comment")
...

When I want to refer to a particular string, I do so by its macro name. This method has been working nicely for me, but I'm concerned that such blatant abuse of #define is frowned upon. From the standpoint of "correctness", should I just inline each NSLocalizedString with the code, or is there another method (extern NSString *aString; perhaps?) that I can use to collect the declarations in one place?


Apple provide the genstrings utility that can generate your strings file directly from the source code automatically. This means you can probably just inline your NSLocalizedStrings.

http://developer.apple.com/mac/library/documentation/Darwin/Reference/ManPages/man1/genstrings.1.html

0

精彩评论

暂无评论...
验证码 换一张
取 消