在使用qt的browserplugin框架写npapi插件时发现一个奇怪的现象,产生的日志内容一开始还是正确的,在关闭的时候日志突然就变了。遇到这么奇怪的现象,很是郁闷,但是程序不会说谎的,肯定还是某个地方出问题了。
根据现象是在关闭的时候日志才被改了,说明关闭的时候因为什么原因让日志内容被覆盖了,而且日志内容看起来还是还是比较完整的,有初始化也有销毁。
修改创建日志文件的代码,创建出来不同的日志文件,而不覆盖原来的。这次发现确实生成的时候是两份日志,而且日志内容几乎一样。第二份日志缺少了一些中间过程的日志,说明插件的初始化和销毁被调用了两次,两次调用的处理条件还不太一样。
既然确定了是创建了两次日志,那么打上断点,跟一下第二次日志创建的调用逻辑。发现是在NPP_SetWindow的时候再次调用了创建插件中的对象,这时候初始化过程又走了一遍。
根据NPAPI的介绍,在销毁窗口的时候还是会调用NPP_SetWindow,但是NPWindow的变量window是nullptr,这时我们就没必要再次创建对象了。
找到原因就好办了,只需要在合适的位置加上判断代码即可
if (window->window == NULL)
return NPERR_NO_ERROR;
qt实现的这个函数,前半部分都是在销毁已经存在的对象,所以我们只要在对象销毁完毕,要初始化的时候加上这个判断即可。
具体位置如下:
This->window = (QtNPInstance::Widget)window->window;
#ifdef Q_WS_X11
//This->display = ((NPSetWindowCallbackStruct *)window->ws_info)->display;
#endif
if (window->window == NULL)
return NPERR_NO_ERROR;
extern void qtns_initialize(QtNPInstance*);
qtns_initialize(This);
编译再次运行OK啦。