1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/unix/mimetype.h
3 // Purpose: classes and functions to manage MIME types
4 // Author: Vadim Zeitlin
8 // Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
9 // Licence: wxWindows licence (part of wxExtra library)
10 /////////////////////////////////////////////////////////////////////////////
12 #ifndef _MIMETYPE_IMPL_H
13 #define _MIMETYPE_IMPL_H
15 #if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
16 #pragma interface "mimetype.h"
19 #include "wx/mimetype.h"
21 #if (wxUSE_FILE && wxUSE_TEXTFILE)
23 class wxMimeTypeCommands
;
25 WX_DEFINE_ARRAY(wxMimeTypeCommands
*, wxMimeCommandsArray
);
27 // this is the real wxMimeTypesManager for Unix
28 class WXDLLEXPORT wxMimeTypesManagerImpl
32 wxMimeTypesManagerImpl();
33 ~wxMimeTypesManagerImpl();
35 // load all data into memory - done when it is needed for the first time
36 void Initialize(int mailcapStyles
= wxMAILCAP_ALL
,
37 const wxString
& extraDir
= wxEmptyString
);
39 // and delete the data here
42 // implement containing class functions
43 wxFileType
*GetFileTypeFromExtension(const wxString
& ext
);
44 wxFileType
*GetFileTypeFromMimeType(const wxString
& mimeType
);
46 size_t EnumAllFileTypes(wxArrayString
& mimetypes
);
48 bool ReadMailcap(const wxString
& filename
, bool fallback
= FALSE
);
49 bool ReadMimeTypes(const wxString
& filename
);
51 void AddFallback(const wxFileTypeInfo
& filetype
);
53 // add information about the given mimetype
54 void AddMimeTypeInfo(const wxString
& mimetype
,
55 const wxString
& extensions
,
56 const wxString
& description
);
57 void AddMailcapInfo(const wxString
& strType
,
58 const wxString
& strOpenCmd
,
59 const wxString
& strPrintCmd
,
60 const wxString
& strTest
,
61 const wxString
& strDesc
);
63 // add a new record to the user .mailcap/.mime.types files
64 wxFileType
*Associate(const wxFileTypeInfo
& ftInfo
);
66 bool Unassociate(wxFileType
*ft
);
69 // get the string containing space separated extensions for the given
71 wxString
GetExtension(size_t index
) { return m_aExtensions
[index
]; }
76 wxArrayString m_aTypes
, // MIME types
77 m_aDescriptions
, // descriptions (just some text)
78 m_aExtensions
, // space separated list of extensions
79 m_aIcons
; // Icon filenames
81 // verb=command pairs for this file type
82 wxMimeCommandsArray m_aEntries
;
84 // are we initialized?
87 // keep track of the files we had already loaded (this is a bitwise OR of
88 // wxMailcapStyle values)
89 int m_mailcapStylesInited
;
91 wxString
GetCommand(const wxString
&verb
, size_t nIndex
) const;
94 void LoadGnomeDataFromKeyFile(const wxString
& filename
,
95 const wxArrayString
& dirs
);
96 void LoadGnomeMimeTypesFromMimeFile(const wxString
& filename
);
97 void LoadGnomeMimeFilesFromDir(const wxString
& dirbase
,
98 const wxArrayString
& dirs
);
99 void GetGnomeMimeInfo(const wxString
& sExtraDir
);
102 bool CheckGnomeDirsExist();
103 bool WriteGnomeKeyFile(int index
, bool delete_index
);
104 bool WriteGnomeMimeFile(int index
, bool delete_index
);
107 void LoadKDELinksForMimeSubtype(const wxString
& dirbase
,
108 const wxString
& subdir
,
109 const wxString
& filename
,
110 const wxArrayString
& icondirs
);
111 void LoadKDELinksForMimeType(const wxString
& dirbase
,
112 const wxString
& subdir
,
113 const wxArrayString
& icondirs
);
114 void LoadKDELinkFilesFromDir(const wxString
& dirbase
,
115 const wxArrayString
& icondirs
);
116 void GetKDEMimeInfo(const wxString
& sExtraDir
);
119 bool WriteKDEMimeFile(int index
, bool delete_index
);
120 bool CheckKDEDirsExist(const wxString
& sOK
, const wxString
& sTest
);
122 //read write Netscape and MetaMail formats
123 void GetMimeInfo (const wxString
& sExtraDir
);
124 bool WriteToMailCap (int index
, bool delete_index
);
125 bool WriteToMimeTypes (int index
, bool delete_index
);
126 bool WriteToNSMimeTypes (int index
, bool delete_index
);
128 // ReadMailcap() helper
129 bool ProcessOtherMailcapField(struct MailcapLineData
& data
,
130 const wxString
& curField
);
132 // functions used to do associations
134 int AddToMimeData(const wxString
& strType
,
135 const wxString
& strIcon
,
136 wxMimeTypeCommands
*entry
,
137 const wxArrayString
& strExtensions
,
138 const wxString
& strDesc
,
139 bool replaceExisting
= TRUE
);
141 bool DoAssociation(const wxString
& strType
,
142 const wxString
& strIcon
,
143 wxMimeTypeCommands
*entry
,
144 const wxArrayString
& strExtensions
,
145 const wxString
& strDesc
);
147 bool WriteMimeInfo(int nIndex
, bool delete_mime
);
149 // give it access to m_aXXX variables
150 friend class WXDLLEXPORT wxFileTypeImpl
;
155 class WXDLLEXPORT wxFileTypeImpl
158 // initialization functions
159 // this is used to construct a list of mimetypes which match;
160 // if built with GetFileTypeFromMimetype index 0 has the exact match and
161 // index 1 the type / * match
162 // if built with GetFileTypeFromExtension, index 0 has the mimetype for
163 // the first extension found, index 1 for the second and so on
165 void Init(wxMimeTypesManagerImpl
*manager
, size_t index
)
166 { m_manager
= manager
; m_index
.Add(index
); }
169 bool GetExtensions(wxArrayString
& extensions
);
170 bool GetMimeType(wxString
*mimeType
) const
171 { *mimeType
= m_manager
->m_aTypes
[m_index
[0]]; return TRUE
; }
172 bool GetMimeTypes(wxArrayString
& mimeTypes
) const;
173 bool GetIcon(wxIconLocation
*iconLoc
) const;
175 bool GetDescription(wxString
*desc
) const
176 { *desc
= m_manager
->m_aDescriptions
[m_index
[0]]; return TRUE
; }
178 bool GetOpenCommand(wxString
*openCmd
,
179 const wxFileType::MessageParameters
& params
) const
181 *openCmd
= GetExpandedCommand(wxT("open"), params
);
182 return (! openCmd
-> IsEmpty() );
185 bool GetPrintCommand(wxString
*printCmd
,
186 const wxFileType::MessageParameters
& params
) const
188 *printCmd
= GetExpandedCommand(wxT("print"), params
);
189 return (! printCmd
-> IsEmpty() );
192 // return the number of commands defined for this file type, 0 if none
193 size_t GetAllCommands(wxArrayString
*verbs
, wxArrayString
*commands
,
194 const wxFileType::MessageParameters
& params
) const;
197 // remove the record for this file type
198 // probably a mistake to come here, use wxMimeTypesManager.Unassociate (ft) instead
199 bool Unassociate(wxFileType
*ft
)
201 return m_manager
->Unassociate(ft
);
204 // set an arbitrary command, ask confirmation if it already exists and
205 // overwriteprompt is TRUE
206 bool SetCommand(const wxString
& cmd
, const wxString
& verb
, bool overwriteprompt
= TRUE
);
207 bool SetDefaultIcon(const wxString
& strIcon
= wxEmptyString
, int index
= 0);
211 GetExpandedCommand(const wxString
& verb
,
212 const wxFileType::MessageParameters
& params
) const;
214 wxMimeTypesManagerImpl
*m_manager
;
215 wxArrayInt m_index
; // in the wxMimeTypesManagerImpl arrays