+            if (nIndex < (int) file.GetLineCount()) file.CommentLine (nIndex);
+        }
+
+        sTmp = sTmp + wxT(";") + sCmd; //includes wxT(" %s ");
+
+        // write it in the format that Netscape uses (default)
+        if (! ( m_mailcapStylesInited & wxMAILCAP_STANDARD  ) )
+        {
+            if (! delete_index) file.InsertLine (sTmp, nIndex);
+            nIndex ++;
+        }
+
+        // write extended format
+        else
+        {
+            // todo FIX this code;
+            // ii) lost entries
+            // sOld holds all the entries, but our data store only has some
+            // eg test= is not stored
+
+            // so far we have written the mimetype and command out
+            wxStringTokenizer sT (sOld, wxT(";\\"));
+            if (sT.CountTokens () > 2)
+            {
+                // first one mimetype; second one command, rest unknown...
+                wxString s;
+                s = sT.GetNextToken();
+                s = sT.GetNextToken();
+
+                // first unknown
+                s = sT.GetNextToken();
+                while ( ! s.empty() )
+                {
+                    bool bKnownToken = FALSE;
+                    if (s.Contains(wxT("description="))) bKnownToken = TRUE;
+                    if (s.Contains(wxT("x11-bitmap="))) bKnownToken = TRUE;
+                    size_t i;
+                    for (i=0; i < entries->GetCount(); i++)
+                    {
+                        if (s.Contains(entries->GetVerb(i))) bKnownToken = TRUE;
+                    }
+                    if (!bKnownToken)
+                    {
+                        sTmp = sTmp + wxT("; \\");
+                        file.InsertLine (sTmp, nIndex);
+                        sTmp = s;
+                    }
+                    s = sT.GetNextToken ();
+                }
+
+            }
+
+            if (! m_aDescriptions[index].empty() )
+            {
+                sTmp = sTmp + wxT("; \\");
+                file.InsertLine (sTmp, nIndex);
+                nIndex ++;
+                sTmp = wxT("       description=\"") + m_aDescriptions[index] + wxT("\"");
+            }
+
+            if (! m_aIcons[index].empty() )
+            {
+                sTmp = sTmp + wxT("; \\");
+                file.InsertLine (sTmp, nIndex);
+                nIndex ++;
+                sTmp = wxT("       x11-bitmap=\"") + m_aIcons[index] + wxT("\"");
+            }
+            if ( entries->GetCount() > 1 )
+
+            {
+                size_t i;
+                for (i=0; i < entries->GetCount(); i++)
+                    if ( i != iOpen )
+                    {
+                        sTmp = sTmp + wxT("; \\");
+                        file.InsertLine (sTmp, nIndex);
+                        nIndex ++;
+                        sTmp = wxT("       ") + entries->GetVerbCmd(i);
+                    }
+            }
+
+            file.InsertLine (sTmp, nIndex);
+            nIndex ++;
+
+        }
+        bTemp = file.Write ();
+        file.Close ();
+    }
+    return bTemp;
+}
+
+wxFileType *
+wxMimeTypesManagerImpl::Associate(const wxFileTypeInfo& ftInfo)
+{
+    InitIfNeeded();
+
+    wxString strType = ftInfo.GetMimeType ();
+    wxString strDesc = ftInfo.GetDescription ();
+    wxString strIcon = ftInfo.GetIconFile ();
+
+    wxMimeTypeCommands *entry = new wxMimeTypeCommands ();
+
+    if ( ! ftInfo.GetOpenCommand().empty())
+        entry->Add(wxT("open=")  + ftInfo.GetOpenCommand  () + wxT(" %s "));
+    if ( ! ftInfo.GetPrintCommand  ().empty())
+        entry->Add(wxT("print=") + ftInfo.GetPrintCommand () + wxT(" %s "));
+
+    // now find where these extensions are in the data store and remove them
+    wxArrayString sA_Exts = ftInfo.GetExtensions ();
+    wxString sExt, sExtStore;
+    size_t i, nIndex;
+    for (i=0; i < sA_Exts.GetCount(); i++)
+        {
+        sExt = sA_Exts.Item(i);
+        //clean up to just a space before and after
+        sExt.Trim().Trim(FALSE);
+        sExt = wxT(' ') + sExt + wxT(' ');
+        for (nIndex = 0; nIndex < m_aExtensions.GetCount(); nIndex ++)
+            {
+            sExtStore = m_aExtensions.Item(nIndex);
+            if (sExtStore.Replace(sExt, wxT(" ") ) > 0) m_aExtensions.Item(nIndex) = sExtStore;
+    }