Динамическое подключение на Mac OS X, крошечный пример
Шаги:
: Вы "просто" хотите создать библиотеку для других модулей для использования. Однако существует пугающая груда программ - gcc, ld, macosx libtool, dyld - с огромным количеством опций, некоторым хорошо гнившим компостом и различиями между MacOSX и Linux. Существуют тонны страниц справочника (я количество 7679 + 1358 + 228 + 226 строк в 10.4.11 PPC), но не очень в способе примеров, или программы с "говорят мне, что Вы делаете" режим.
(Самая важная вещь в понимании состоит в том, чтобы сделать упрощенный ОБЗОР для себя: нарисуйте некоторые изображения, выполните некоторые небольшие примеры, объясните это кому-то еще).
Фон: apple OverviewOfDynamicLibraries , Википедия Dynamic_library
Шаг 1, создает libmylib.dylib -
mymod.c:
#include
void mymod( int x )
{
printf( "mymod: %d\n", x );
}
gcc -c mymod.c # -> mymod.o
gcc -dynamiclib -current_version 1.0 mymod.o -o libmylib.dylib
# calls libtool with many options -- see man libtool
# -compatibility_version is used by dyld, see also cmpdylib
file libmylib.dylib # Mach-O dynamically linked shared library ppc
otool -L libmylib.dylib # versions, refs /usr/lib/libgcc_s.1.dylib
Шаг 2, компилирует и связывает callmymod -
callmymod.c:
extern void mymod( int x );
int main( int argc, char** argv )
{
mymod( 42 );
}
gcc -c callmymod.c
gcc -v callmymod.o ./libmylib.dylib -o callmymod
# == gcc callmymod.o -dynamic -L. -lmylib
otool -L callmymod # refs libmylib.dylib
nm -gpv callmymod # U undef _mymod: just a reference, not mymod itself
Шаг 3, выполняет соединение callmymod с libmylib.dylib -
export DYLD_PRINT_LIBRARIES=1 # see what dyld does, for ALL programs
./callmymod
dyld: loaded: libmylib.dylib ...
mymod: 42
mv libmylib.dylib /tmp
export DYLD_LIBRARY_PATH=/tmp # dir:dir:...
./callmymod
dyld: loaded: /tmp/libmylib.dylib ...
mymod: 42
unset DYLD_PRINT_LIBRARIES
unset DYLD_LIBRARY_PATH
, Который заканчивает один крошечный пример; надежда это помогает понять шаги.
(Если Вы делаете это много, см. GNU Libtool, который является glibtool на макинтошах, и SCons.)
аплодисменты
- denis
Похоже, здесь есть ответ:
Как исправить ошибку NSURLErrorDomain -999 в ОС iPhone 3.0
, которая, в свою очередь, относится к:
Похоже, вам нужен такой взлом в webView: didFailLoadWithError: delegate:
if ([error code] != NSURLErrorCancelled) {
//show error alert, etc.
}
По сути, происходит то, что делегат получает сбой "отменен" (-999), который может быть вызван javascript или, возможно, даже ошибкой UIWebView.
С вашим кодом веб-просмотр вообще ничего не показывает, потому что вы используете тот же UIWebView для отображения ошибки. Если бы у вас была только NSLog'd ошибка, вы бы увидели сбой, но тогда страница загрузилась бы нормально, давая вам подсказку, что сбой является фиктивным.