事实证明,内联显示(甚至可能首先生成图像)失败了,因为 matplotlib 无法加载Vera.ttf
字体文件。它试图从错误的文件系统位置加载该文件,该位置是进程无法访问的,该进程在 OS X 沙箱中运行。
10/29/13 11:59:02.000 PM kernel[0]: Sandbox: python(24173) deny file-read-data $HOME/Library/Developer/Xcode/DerivedData/IPython_Notebook-adcshxaaibpeztbztvthgauvufsx/Build/Products/Debug/IPython Notebook.app/Contents/Resources/virtualenv/lib/python2.7/site-packages/matplotlib/mpl-data/fonts/ttf/Vera.ttf
该进程从这个位置运行:
$HOME/Library/Developer/Xcode/DerivedData/IPython_Notebook-adcshxaaibpeztbztvthgauvufsx/Build/Products/Release/IPython Notebook.app
(“调试”与“发布”)
在我删除 Debug 位置并重新启动应用程序后,沙盒消息消失了,内联绘图开始工作。当我将应用程序包复制到另一个位置并从那里启动它时,它再次失败。沙盒违规报告中的堆栈跟踪表明它是 FreeType 尝试从旧位置加载字体:
0 libsystem_kernel.dylib 0x00007fff9054f5da __open + 10
1 libfreetype.dylib 0x000000010b789214 FT_Stream_New + 260
2 libfreetype.dylib 0x000000010b789e00 FT_Open_Face + 144
3 libfreetype.dylib 0x000000010b789d5e FT_New_Face + 46
4 ft2font.so 0x000000010b7259f0 FT2Font::FT2Font(Py::PythonClassInstance*, Py::Tuple&, Py::Dict&) + 698
5 ft2font.so 0x000000010b735fa6 Py::PythonClass<FT2Font>::extension_object_init(_object*, _object*, _object*) + 116
一些调查显示 matplotlib 维护一个fontList.cache
文件,该文件最终位于应用程序的沙箱容器目录中。移动应用程序包后,该缓存文件中的路径无效/不可访问。我在我的应用程序中添加了代码以在启动时删除此缓存文件。
所以不是真正的 IPython 问题,但我想我会发布这个,以防它有助于将来将笔记本嵌入沙盒 OS X 应用程序的人。