X-Git-Url: http://git.cinelerra-gg.org/git/?a=blobdiff_plain;f=cinelerra-5.1%2Fcinelerra%2Fpluginserver.C;fp=cinelerra-5.1%2Fcinelerra%2Fpluginserver.C;h=20e08325524997f9b29d8710c90c242a5a69a05c;hb=15df6cbff7373d232ae0b8dcaecd9aa51ff5c388;hp=e7d121f6c5e3ed3112ddc3220e8d061f73ee264d;hpb=a9288f4aa494cc2e76d5eb2f54e2a7561c4a35b4;p=goodguy%2Fhistory.git diff --git a/cinelerra-5.1/cinelerra/pluginserver.C b/cinelerra-5.1/cinelerra/pluginserver.C index e7d121f6..20e08325 100644 --- a/cinelerra-5.1/cinelerra/pluginserver.C +++ b/cinelerra-5.1/cinelerra/pluginserver.C @@ -1222,17 +1222,24 @@ Theme* PluginServer::get_theme() } -int PluginServer::get_plugin_png_path(char *png_path, const char *plugin_icons) +void PluginServer::get_plugin_png_name(char *png_name) { - char *pp = png_path, *ep = pp + BCTEXTLEN-1; - pp += snprintf(pp, ep-pp, "%s/picon_%s/", - File::get_plugin_path(), plugin_icons); + char *pp = png_name, *ep = pp + BCSTRLEN-1; char *cp = strrchr(path, '/'); cp = !cp ? path : cp+1; char *sp = strrchr(cp, '.'); if( !sp ) sp = cp+strlen(cp); while( pp < ep && cp < sp ) *pp++ = *cp++; snprintf(pp, ep-pp, ".png"); +} + +int PluginServer::get_plugin_png_path(char *png_path, const char *plugin_icons) +{ + char png_name[BCSTRLEN]; + get_plugin_png_name(png_name); + char *pp = png_path, *ep = pp + BCTEXTLEN-1; + pp += snprintf(pp, ep-pp, "%s/picon_%s/%s", + File::get_plugin_path(), plugin_icons, png_name); return access(png_path,R_OK) ? 1 : 0; } @@ -1246,8 +1253,12 @@ int PluginServer::get_plugin_png_path(char *png_path) VFrame *PluginServer::get_plugin_images() { char png_path[BCTEXTLEN]; - if( get_plugin_png_path(png_path) ) return 0; - return VFramePng::vframe_png(png_path,0,0); + if( !get_plugin_png_path(png_path) ) + return VFramePng::vframe_png(png_path,0,0); + char png_name[BCSTRLEN]; + get_plugin_png_name(png_name); + unsigned char *data = mwindow->theme->get_image_data(png_name); + return data ? new VFramePng(data, 0.) : 0; } VFrame *PluginServer::get_picon()