CHMReader compile issues on Mac 
Mozilla June 8th, 2009
CHM Reader is a great extension make Firefox support .chm file, project host on:http://sourceforge.net/projects/chmreader/
When I compiled it on my OSX 10.5.7 occurred following issue:
1 2 3 | g++ -o components/mozCHMModule.os -c -fPIC -I/Users/duo/xulrunner-sdk/include -I/Users/duo/xulrunner-sdk/sdk/include components/mozCHMModule.cpp /Users/duo/xulrunner-sdk/sdk/include/nsStringAPI.h:1053: error: size of array 'arg' is negative scons: *** [components/mozCHMModule.os] Error 1 |
The line in nsStringAPI.h is PR_STATIC_ASSERT(sizeof(wchar_t) == 2), but 4-bytes is the default wide character size on macs, so we should add -fshort-wchar to compile flag options.
The other issue in link stage:
1 2 3 4 | g++ -o platform/Darwin_x86-gcc3/components/libchm.dylib -dynamiclib components/chm_lib.os components/lzx.os components/mozCHMModule.os components/mozCHMFile.os components/mozCHMUnitInfo.os components/mozCHMInputStream.os -L/Users/duo/xulrunner-sdk/lib -L/Users/duo/xulrunner-sdk/sdk/lib -lxpcom -lxpcomglue_s -lnspr4 -lplds4 -lplc4 ld: file not found: @executable_path/libsmime3.dylib collect2: ld returned 1 exit status scons: *** [platform/Darwin_x86-gcc3/components/libchm.dylib] Error 1 |
Just add -Wl,-executable_path -Wl,/path/to/gecko/sdk/bin to link flag options.
Complete svn diff result:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | Index: components/SConscript =================================================================== --- components/SConscript (revision 114) +++ components/SConscript (working copy) @@ -7,6 +7,8 @@ libs = ['xpcom', 'xpcomglue_s', 'nspr4', 'plds4', 'plc4'] +linkflags = '' + # We use firefox development files instead for geckosdk on FreeBSD if system() != 'FreeBSD': try: @@ -38,7 +40,8 @@ cpppath.append('/usr/include/nspr') elif system() == 'Darwin': - cxxflags = [] + cxxflags = ['-fshort-wchar'] + linkflags = ['-Wl,-executable_path', '-Wl,%s/bin' % geckosdk] elif system() == 'Windows': cxxflags = ['/D', 'WIN32', '/D', 'XP_WIN', '/nologo', '/MT', '/O2'] @@ -70,7 +73,7 @@ '/usr/local/lib/firefox3/sdk/lib'] env = Environment(CPPPATH = cpppath, LIBPATH = libpath, LIBS = libs, - CXXFLAGS= cxxflags) + CXXFLAGS= cxxflags, LINKFLAGS = linkflags) bxpt = Builder( action = 'xpidl -w -m typelib -Icomponents -I%s -I%s -e $TARGET $SOURCE' \ |
Related posts:
Thanks for the useful info. It’s so interesting