X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/805f26b316f6e170226d9e91e93f8a3d82a79c70..05b4b8ee882d86d1095efe72e5c866d80bb4cc95:/include/wx/unix/mimetype.h diff --git a/include/wx/unix/mimetype.h b/include/wx/unix/mimetype.h index bfe5a7277f..a5166f638d 100644 --- a/include/wx/unix/mimetype.h +++ b/include/wx/unix/mimetype.h @@ -6,31 +6,27 @@ // Created: 23.09.98 // RCS-ID: $Id$ // Copyright: (c) 1998 Vadim Zeitlin -// Licence: wxWindows license (part of wxExtra library) +// Licence: wxWindows licence (part of wxExtra library) ///////////////////////////////////////////////////////////////////////////// #ifndef _MIMETYPE_IMPL_H #define _MIMETYPE_IMPL_H -#if defined(__GNUG__) && !defined(__APPLE__) -#pragma interface "mimetype.h" -#endif - #include "wx/mimetype.h" -#if (wxUSE_FILE && wxUSE_TEXTFILE) +#if wxUSE_MIMETYPE class wxMimeTypeCommands; -WX_DEFINE_ARRAY(wxMimeTypeCommands *, wxMimeCommandsArray); +WX_DEFINE_ARRAY_PTR(wxMimeTypeCommands *, wxMimeCommandsArray); // this is the real wxMimeTypesManager for Unix -class WXDLLEXPORT wxMimeTypesManagerImpl +class WXDLLIMPEXP_BASE wxMimeTypesManagerImpl { public: // ctor and dtor wxMimeTypesManagerImpl(); - ~wxMimeTypesManagerImpl(); + virtual ~wxMimeTypesManagerImpl(); // load all data into memory - done when it is needed for the first time void Initialize(int mailcapStyles = wxMAILCAP_ALL, @@ -70,15 +66,8 @@ public: // file type wxString GetExtension(size_t index) { return m_aExtensions[index]; } -private: - void InitIfNeeded() - { - if ( !m_initialized ) { - // set the flag first to prevent recursion - m_initialized = TRUE; - Initialize(); - } - } +protected: + void InitIfNeeded(); wxArrayString m_aTypes, // MIME types m_aDescriptions, // descriptions (just some text) @@ -105,11 +94,6 @@ private: const wxArrayString& dirs); void GetGnomeMimeInfo(const wxString& sExtraDir); - // write gnome files - bool CheckGnomeDirsExist(); - bool WriteGnomeKeyFile(int index, bool delete_index); - bool WriteGnomeMimeFile(int index, bool delete_index); - // read KDE void LoadKDELinksForMimeSubtype(const wxString& dirbase, const wxString& subdir, @@ -120,6 +104,8 @@ private: const wxArrayString& icondirs); void LoadKDELinkFilesFromDir(const wxString& dirbase, const wxArrayString& icondirs); + void LoadKDEApp(const wxString& filename); + void LoadKDEAppsFilesFromDir(const wxString& dirname); void GetKDEMimeInfo(const wxString& sExtraDir); // write KDE @@ -138,28 +124,26 @@ private: // functions used to do associations - int AddToMimeData(const wxString& strType, + virtual int AddToMimeData(const wxString& strType, const wxString& strIcon, wxMimeTypeCommands *entry, const wxArrayString& strExtensions, const wxString& strDesc, bool replaceExisting = TRUE); - bool DoAssociation(const wxString& strType, + virtual bool DoAssociation(const wxString& strType, const wxString& strIcon, wxMimeTypeCommands *entry, const wxArrayString& strExtensions, const wxString& strDesc); - bool WriteMimeInfo(int nIndex, bool delete_mime ); + virtual bool WriteMimeInfo(int nIndex, bool delete_mime ); // give it access to m_aXXX variables - friend class WXDLLEXPORT wxFileTypeImpl; + friend class WXDLLIMPEXP_FWD_BASE wxFileTypeImpl; }; - - -class WXDLLEXPORT wxFileTypeImpl +class WXDLLIMPEXP_BASE wxFileTypeImpl { public: // initialization functions @@ -177,8 +161,7 @@ public: bool GetMimeType(wxString *mimeType) const { *mimeType = m_manager->m_aTypes[m_index[0]]; return TRUE; } bool GetMimeTypes(wxArrayString& mimeTypes) const; - bool GetIcon(wxIcon *icon, wxString *iconFile = NULL, - int *iconIndex = NULL) const; + bool GetIcon(wxIconLocation *iconLoc) const; bool GetDescription(wxString *desc) const { *desc = m_manager->m_aDescriptions[m_index[0]]; return TRUE; } @@ -223,9 +206,8 @@ private: wxArrayInt m_index; // in the wxMimeTypesManagerImpl arrays }; -#endif - // wxUSE_FILE +#endif // wxUSE_MIMETYPE + +#endif // _MIMETYPE_IMPL_H -#endif - //_MIMETYPE_IMPL_H