]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/fltfactory.tex
remove just added wxCoordRound() (see patch 1586499)
[wxWidgets.git] / docs / latex / wx / fltfactory.tex
CommitLineData
716b1f70
MW
1%
2% automatically generated by HelpGen $Revision$ from
3% include/wx/stream.h at 28/Oct/06 18:49:10
4%
5
6\section{\class{wxFilterClassFactory}}\label{wxfilterclassfactory}
7
8Allows the creation of filter streams to handle compression formats such
9as gzip and bzip2.
10
11For example, given a filename you can search for a factory that will
12handle it and create a stream to decompress it:
13
14\begin{verbatim}
15 factory = wxFilterClassFactory::Find(filename, wxSTREAM_FILEEXT);
16 if (factory)
17 stream = factory->NewStream(new wxFFileInputStream(filename));
18
19\end{verbatim}
20
21\helpref{Find()}{wxfilterclassfactoryfind} can also search
22for a factory by MIME type, HTTP encoding or by wxFileSystem protocol.
23The available factories can be enumerated
24using \helpref{GetFirst() and GetNext()}{wxfilterclassfactorygetfirst}.
25
26\wxheading{Derived from}
27
28\helpref{wxObject}{wxobject}
29
30\wxheading{Include files}
31
32<wx/stream.h>
33
34\wxheading{Data structures}
35
36\begin{verbatim}
37enum wxStreamProtocolType
38{
39 wxSTREAM_PROTOCOL, // wxFileSystem protocol (should be only one)
40 wxSTREAM_MIMETYPE, // MIME types the stream handles
41 wxSTREAM_ENCODING, // The HTTP Content-Encodings the stream handles
42 wxSTREAM_FILEEXT // File extensions the stream handles
43};
44
45\end{verbatim}
46
47\wxheading{See also}
48
49\helpref{wxFilterInputStream}{wxfilterinputstream}\\
50\helpref{wxFilterOutputStream}{wxfilteroutputstream}\\
51\helpref{wxArchiveClassFactory}{wxarchiveclassfactory}\\
52\helpref{Archive formats such as zip}{wxarc}
53
54\latexignore{\rtfignore{\wxheading{Members}}}
55
56
57\membersection{wxFilterClassFactory::CanHandle}\label{wxfilterclassfactorycanhandle}
58
59\constfunc{bool}{CanHandle}{\param{const wxChar* }{protocol}, \param{wxStreamProtocolType }{type = wxSTREAM\_PROTOCOL}}
60
61Returns true if this factory can handle the given protocol, MIME type, HTTP
62encoding or file extension.
63
64When using wxSTREAM\_FILEEXT for the second parameter, the first parameter
65can be a complete filename rather than just an extension.
66
67
68\membersection{wxFilterClassFactory::Find}\label{wxfilterclassfactoryfind}
69
70\func{static const wxFilterClassFactory*}{Find}{\param{const wxChar* }{protocol}, \param{wxStreamProtocolType }{type = wxSTREAM\_PROTOCOL}}
71
72A static member that finds a factory that can handle a given protocol, MIME
73type, HTTP encoding or file extension. Returns a pointer to the class
74factory if found, or NULL otherwise. It does not give away ownership of the
75factory.
76
77When using wxSTREAM\_FILEEXT for the second parameter, the first parameter
78can be a complete filename rather than just an extension.
79
80
81\membersection{wxFilterClassFactory::GetFirst/GetNext}\label{wxfilterclassfactorygetfirst}
82
83\func{static const wxFilterClassFactory*}{GetFirst}{\void}
84
85\constfunc{const wxFilterClassFactory*}{GetNext}{\void}
86
87GetFirst and GetNext can be used to enumerate the available factories.
88
89For example, to list them:
90
91\begin{verbatim}
92 wxString list;
93 const wxFilterClassFactory *factory = wxFilterClassFactory::GetFirst();
94
95 while (factory) {
96 list << factory->GetProtocol() << _T("\n");
97 factory = factory->GetNext();
98 }
99
100\end{verbatim}
101
102GetFirst()/GetNext() return a pointer to a factory or NULL if no more
103are available. They do not give away ownership of the factory.
104
105
106\membersection{wxFilterClassFactory::GetProtocol}\label{wxfilterclassfactorygetprotocol}
107
108\constfunc{wxString}{GetProtocol}{\void}
109
110Returns the wxFileSystem protocol supported by this factory. Equivalent
111to wxString(*GetProtcols()).
112
113
114\membersection{wxFilterClassFactory::GetProtocols}\label{wxfilterclassfactorygetprotocols}
115
116\constfunc{const wxChar * const*}{GetProtocols}{\param{wxStreamProtocolType }{type = wxSTREAM\_PROTOCOL}}
117
118Returns the protocols, MIME types, HTTP encodings or file extensions
119supported by this factory, as an array of null terminated strings. It does
120not give away ownership of the array or strings.
121
122For example, to list the file extensions a factory supports:
123
124\begin{verbatim}
125 wxString list;
126 const wxChar *const *p;
127
128 for (p = factory->GetProtocols(wxSTREAM_FILEEXT); *p; p++)
129 list << *p << _T("\n");
130
131\end{verbatim}
132
133
134\membersection{wxFilterClassFactory::NewStream}\label{wxfilterclassfactorynewstream}
135
136\constfunc{wxFilterInputStream*}{NewStream}{\param{wxInputStream\& }{stream}}
137
138\constfunc{wxFilterOutputStream*}{NewStream}{\param{wxOutputStream\& }{stream}}
139
140\constfunc{wxFilterInputStream*}{NewStream}{\param{wxInputStream* }{stream}}
141
142\constfunc{wxFilterOutputStream*}{NewStream}{\param{wxOutputStream* }{stream}}
143
144Create a new input or output stream to decompress or compress a given stream.
145
146If the parent stream is passed as a pointer then the new filter stream
147takes ownership of it. If it is passed by reference then it does not.
148
149
150\membersection{wxFilterClassFactory::PopExtension}\label{wxfilterclassfactorypopextension}
151
152\constfunc{wxString}{PopExtension}{\param{const wxString\& }{location}}
153
154Remove the file extension of {\it location} if it is one of the file
155extensions handled by this factory.
156
157
158\membersection{wxFilterClassFactory::PushFront}\label{wxfilterclassfactorypushfront}
159
160\func{void}{PushFront}{\void}
161
162Adds this class factory to the list returned
163by \helpref{GetFirst()/GetNext()}{wxfilterclassfactorygetfirst}.
164
165It is not necessary to do this to use the filter streams. It is usually
166used when implementing streams, typically the implementation will
167add a static instance of its factory class.
168
169It can also be used to change the order of a factory already in the list,
170bringing it to the front. This isn't a thread safe operation
171so can't be done when other threads are running that will be using the list.
172
173The list does not take ownership of the factory.
174
175
176\membersection{wxFilterClassFactory::Remove}\label{wxfilterclassfactoryremove}
177
178\func{void}{Remove}{\void}
179
180Removes this class factory from the list returned
181by \helpref{GetFirst()/GetNext()}{wxfilterclassfactorygetfirst}.
182
183Removing from the list isn't a thread safe operation
184so can't be done when other threads are running that will be using the list.
185
186The list does not own the factories, so removing a factory does not delete it.