|
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ |
|
2 /* This Source Code Form is subject to the terms of the Mozilla Public |
|
3 * License, v. 2.0. If a copy of the MPL was not distributed with this |
|
4 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ |
|
5 |
|
6 #include "nsIStreamListener.idl" |
|
7 |
|
8 interface nsIUnicharInputStream; |
|
9 interface nsIUnicharStreamLoader; |
|
10 interface nsIChannel; |
|
11 |
|
12 [scriptable, uuid(c2982b39-2e48-429e-92b7-99348a1633c5)] |
|
13 interface nsIUnicharStreamLoaderObserver : nsISupports |
|
14 { |
|
15 /** |
|
16 * Called as soon as at least 512 octets of data have arrived. |
|
17 * If the stream receives fewer than 512 octets of data in total, |
|
18 * called upon stream completion but before calling OnStreamComplete. |
|
19 * Will not be called if the stream receives no data at all. |
|
20 * |
|
21 * @param aLoader the unichar stream loader |
|
22 * @param aContext the context parameter of the underlying channel |
|
23 * @param aSegment up to 512 octets of raw data from the stream |
|
24 * |
|
25 * @return the name of the character set to be used to decode this stream |
|
26 */ |
|
27 ACString onDetermineCharset(in nsIUnicharStreamLoader aLoader, |
|
28 in nsISupports aContext, |
|
29 in ACString aSegment); |
|
30 |
|
31 /** |
|
32 * Called when the entire stream has been loaded and decoded. |
|
33 * |
|
34 * @param aLoader the unichar stream loader |
|
35 * @param aContext the context parameter of the underlying channel |
|
36 * @param aStatus the status of the underlying channel |
|
37 * @param aBuffer the contents of the stream, decoded to UTF-16. |
|
38 * |
|
39 * This method will always be called asynchronously by the |
|
40 * nsUnicharIStreamLoader involved, on the thread that called the |
|
41 * loader's init() method. If onDetermineCharset fails, |
|
42 * onStreamComplete will still be called, but aStatus will be an |
|
43 * error code. |
|
44 */ |
|
45 void onStreamComplete(in nsIUnicharStreamLoader aLoader, |
|
46 in nsISupports aContext, |
|
47 in nsresult aStatus, |
|
48 in AString aBuffer); |
|
49 }; |
|
50 |
|
51 /** |
|
52 * Asynchronously load a channel, converting the data to UTF-16. |
|
53 * |
|
54 * To use this interface, first call init() with a |
|
55 * nsIUnicharStreamLoaderObserver that will be notified when the data has been |
|
56 * loaded. Then call asyncOpen() on the channel with the nsIUnicharStreamLoader |
|
57 * as the listener. The context argument in the asyncOpen() call will be |
|
58 * passed to the onStreamComplete() callback. |
|
59 */ |
|
60 [scriptable, uuid(afb62060-37c7-4713-8a84-4a0c1199ba5c)] |
|
61 interface nsIUnicharStreamLoader : nsIStreamListener |
|
62 { |
|
63 /** |
|
64 * Initializes the unichar stream loader |
|
65 * |
|
66 * @param aObserver the observer to notify when a charset is needed and when |
|
67 * the load is complete |
|
68 */ |
|
69 void init(in nsIUnicharStreamLoaderObserver aObserver); |
|
70 |
|
71 /** |
|
72 * The channel attribute is only valid inside the onDetermineCharset |
|
73 * and onStreamComplete callbacks. Otherwise it will be null. |
|
74 */ |
|
75 readonly attribute nsIChannel channel; |
|
76 |
|
77 /** |
|
78 * The charset that onDetermineCharset returned, if that's been |
|
79 * called. |
|
80 */ |
|
81 readonly attribute ACString charset; |
|
82 }; |