-void process_xlink(const char* filename, const char *menu_name, const char *base_url, GtkMenu *menu)
-{
- if(file_exists(filename))
- {
- xmlDocPtr pDoc = xmlParseFile(filename);
- if (pDoc)
- {
- globalOutputStream() << "Processing .xlink file '" << filename << "'\n";
- // create sub menu
- GtkMenu* menu_in_menu = create_sub_menu_with_mnemonic(menu, menu_name);
- if (g_Layout_enableDetachableMenus.m_value)
- menu_tearoff (menu_in_menu);
- // start walking the nodes, find the 'links' one
- xmlNodePtr pNode = pDoc->children;
- while (pNode && strcmp((const char*)pNode->name, "links"))
- pNode=pNode->next;
- if (pNode)
- {
- pNode = pNode->children;
- while(pNode)
- {
- if(!strcmp((const char*)pNode->name, "item"))
- {
- // process the URL
- CopiedString url;
-
- xmlChar* prop = xmlGetProp(pNode, reinterpret_cast<const xmlChar*>("url"));
- ASSERT_NOTNULL(prop);
- if(strstr(reinterpret_cast<const char*>(prop), "http://"))
- {
- // complete URL
- url = reinterpret_cast<const char*>(prop);
- }
- else
- {
- // relative URL
- StringOutputStream full(256);
- full << base_url << reinterpret_cast<const char*>(prop);
- url = full.c_str();
- }
-
- mHelpURLs.push_back(url);
-
- xmlFree(prop);
-
- prop = xmlGetProp(pNode, reinterpret_cast<const xmlChar*>("name"));
- ASSERT_NOTNULL(prop);
- create_menu_item_with_mnemonic(menu_in_menu, reinterpret_cast<const char*>(prop), ReferenceCaller<CopiedString, HandleHelpCommand>(mHelpURLs.back()));
- xmlFree(prop);
- }
- pNode=pNode->next;
- }
- }
- xmlFreeDoc(pDoc);
- }
- else
- {
- globalOutputStream() << "'" << filename << "' parse failed\n";
- }
- }
- else
- {
- globalOutputStream() << "'" << filename << "' not found\n";
- }
+void process_xlink( const char* filename, const char *menu_name, const char *base_url, GtkMenu *menu ){
+ if ( file_exists( filename ) ) {
+ xmlDocPtr pDoc = xmlParseFile( filename );
+ if ( pDoc ) {
+ globalOutputStream() << "Processing .xlink file '" << filename << "'\n";
+ // create sub menu
+ GtkMenu* menu_in_menu = create_sub_menu_with_mnemonic( menu, menu_name );
+ if ( g_Layout_enableDetachableMenus.m_value ) {
+ menu_tearoff( menu_in_menu );
+ }
+ // start walking the nodes, find the 'links' one
+ xmlNodePtr pNode = pDoc->children;
+ while ( pNode && strcmp( (const char*)pNode->name, "links" ) )
+ pNode = pNode->next;
+ if ( pNode ) {
+ pNode = pNode->children;
+ while ( pNode )
+ {
+ if ( !strcmp( (const char*)pNode->name, "item" ) ) {
+ // process the URL
+ CopiedString url;
+
+ xmlChar* prop = xmlGetProp( pNode, reinterpret_cast<const xmlChar*>( "url" ) );
+ ASSERT_NOTNULL( prop );
+ if ( strstr( reinterpret_cast<const char*>( prop ), "http://" ) ) {
+ // complete URL
+ url = reinterpret_cast<const char*>( prop );
+ }
+ else
+ {
+ // relative URL
+ StringOutputStream full( 256 );
+ full << base_url << reinterpret_cast<const char*>( prop );
+ url = full.c_str();
+ }
+
+ mHelpURLs.push_back( url );
+
+ xmlFree( prop );
+
+ prop = xmlGetProp( pNode, reinterpret_cast<const xmlChar*>( "name" ) );
+ ASSERT_NOTNULL( prop );
+ create_menu_item_with_mnemonic( menu_in_menu, reinterpret_cast<const char*>( prop ), ReferenceCaller<CopiedString, HandleHelpCommand>( mHelpURLs.back() ) );
+ xmlFree( prop );
+ }
+ pNode = pNode->next;
+ }
+ }
+ xmlFreeDoc( pDoc );
+ }
+ else
+ {
+ globalOutputStream() << "'" << filename << "' parse failed\n";
+ }
+ }
+ else
+ {
+ globalOutputStream() << "'" << filename << "' not found\n";
+ }