author David Anderson <>
Wed, 22 Aug 2012 16:09:24 -0700
changeset 113004 c4f83d9d8243f3f853a5356188164a5fddee2b5a
parent 112525 80e4ab0d24bc64ceaa7693ab5def36faffde7a40
parent 108463 a16372ce30b5f6b747246b01fcd215a4bf3b6342
permissions -rw-r--r--
Merge from mozilla-central.

/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at */

#ifndef nsICharsetDetector_h__
#define nsICharsetDetector_h__

#include "nsISupports.h"

class nsICharsetDetectionObserver;

// {12BB8F14-2389-11d3-B3BF-00805F8A6670}
{ 0x12bb8f14, 0x2389, 0x11d3, { 0xb3, 0xbf, 0x0, 0x80, 0x5f, 0x8a, 0x66, 0x70 } }

#define NS_CHARSET_DETECTOR_CATEGORY "charset-detectors"
class nsICharsetDetector : public nsISupports {

     Setup the observer so it know how to notify the answer
  NS_IMETHOD Init(nsICharsetDetectionObserver* observer) = 0;

     Feed a block of bytes to the detector.
     It will call the Notify function of the nsICharsetObserver if it find out
     the answer. 
     aBytesArray - array of bytes
     aLen        - length of aBytesArray
     oDontFeedMe - return true if the detector do not need the following block
                          false it need more bytes. 
                   This is used to enhance performance
  NS_IMETHOD DoIt(const char* aBytesArray, uint32_t aLen, bool* oDontFeedMe) = 0;

     It also tell the detector the last chance the make a decision
  NS_IMETHOD Done() = 0;



#endif /* nsICharsetDetector_h__ */