1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/msw/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 license (part of wxExtra library)
10 /////////////////////////////////////////////////////////////////////////////
12 #ifndef _MIMETYPE_IMPL_H
13 #define _MIMETYPE_IMPL_H
16 #pragma interface "mimetype.h"
21 #include "wx/mimetype.h"
24 class WXDLLEXPORT wxFileTypeImpl
28 wxFileTypeImpl() { m_info
= NULL
; }
30 // one of these Init() function must be called (ctor can't take any
31 // arguments because it's common)
33 // initialize us with our file type name and extension - in this case
34 // we will read all other data from the registry
35 void Init(const wxString
& strFileType
, const wxString
& ext
);
37 // initialize us with a wxFileTypeInfo object - it contains all the
39 void Init(const wxFileTypeInfo
& info
)
42 // implement accessor functions
43 bool GetExtensions(wxArrayString
& extensions
);
44 bool GetMimeType(wxString
*mimeType
) const;
45 bool GetMimeTypes(wxArrayString
& mimeTypes
) const;
46 bool GetIcon(wxIcon
*icon
, wxString
*sCommand
= NULL
, int *iIndex
= NULL
) const;
47 bool GetDescription(wxString
*desc
) const;
48 bool GetOpenCommand(wxString
*openCmd
,
49 const wxFileType::MessageParameters
& params
) const;
50 bool GetPrintCommand(wxString
*printCmd
,
51 const wxFileType::MessageParameters
& params
) const;
53 size_t GetAllCommands(wxArrayString
* verbs
, wxArrayString
* commands
,
54 const wxFileType::MessageParameters
& params
) const;
56 bool SetCommand(const wxString
& cmd
, const wxString
& verb
,
57 bool overwriteprompt
= true);
58 bool SetMimeType(const wxString
& mimeType
);
59 bool SetDefaultIcon(const wxString
& cmd
= wxEmptyString
, int index
= 0);
61 bool RemoveCommand(const wxString
& verb
);
62 bool RemoveMimeType();
63 bool RemoveDefaultIcon();
66 // helper function: reads the command corresponding to the specified verb
67 // from the registry (returns an empty string if not found)
68 wxString
GetCommand(const wxChar
*verb
) const;
70 // get the registry path for the given verb
71 wxString
GetVerbPath(const wxString
& verb
) const;
73 // check that the registry key for our extension exists, create it if it
74 // doesn't, return FALSE if this failed
75 bool EnsureExtKeyExists();
77 // we use either m_info or read the data from the registry if m_info == NULL
78 const wxFileTypeInfo
*m_info
;
79 wxString m_strFileType
, // may be empty
83 class WXDLLEXPORT wxMimeTypesManagerImpl
86 // nothing to do here, we don't load any data but just go and fetch it from
87 // the registry when asked for
88 wxMimeTypesManagerImpl() { }
90 // implement containing class functions
91 wxFileType
*GetFileTypeFromExtension(const wxString
& ext
);
92 wxFileType
*GetOrAllocateFileTypeFromExtension(const wxString
& ext
) ;
93 wxFileType
*GetFileTypeFromMimeType(const wxString
& mimeType
);
95 size_t EnumAllFileTypes(wxArrayString
& mimetypes
);
97 // this are NOPs under Windows
98 bool ReadMailcap(const wxString
& filename
, bool fallback
= TRUE
)
100 bool ReadMimeTypes(const wxString
& filename
)
103 void AddFallback(const wxFileTypeInfo
& ft
) { m_fallbacks
.Add(ft
); }
105 // create a new filetype with the given name and extension
106 wxFileType
*CreateFileType(const wxString
& filetype
, const wxString
& ext
);
109 wxArrayFileTypeInfo m_fallbacks
;