404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@18.220.235.159: ~ $
######################## BEGIN LICENSE BLOCK ########################
# The Original Code is Mozilla Universal charset detector code.
#
# The Initial Developer of the Original Code is
# Netscape Communications Corporation.
# Portions created by the Initial Developer are Copyright (C) 2001
# the Initial Developer. All Rights Reserved.
#
# Contributor(s):
#   Mark Pilgrim - port to Python
#   Shy Shalom - original C code
#
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 2.1 of the License, or (at your option) any later version.
#
# This library is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with this library; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
# 02110-1301  USA
######################### END LICENSE BLOCK #########################

from .charsetprober import CharSetProber
from .enums import CharacterCategory, ProbingState, SequenceLikelihood


class SingleByteCharSetProber(CharSetProber):
    SAMPLE_SIZE = 64
    SB_ENOUGH_REL_THRESHOLD = 1024  #  0.25 * SAMPLE_SIZE^2
    POSITIVE_SHORTCUT_THRESHOLD = 0.95
    NEGATIVE_SHORTCUT_THRESHOLD = 0.05

    def __init__(self, model, reversed=False, name_prober=None):
        super(SingleByteCharSetProber, self).__init__()
        self._model = model
        # TRUE if we need to reverse every pair in the model lookup
        self._reversed = reversed
        # Optional auxiliary prober for name decision
        self._name_prober = name_prober
        self._last_order = None
        self._seq_counters = None
        self._total_seqs = None
        self._total_char = None
        self._freq_char = None
        self.reset()

    def reset(self):
        super(SingleByteCharSetProber, self).reset()
        # char order of last character
        self._last_order = 255
        self._seq_counters = [0] * SequenceLikelihood.get_num_categories()
        self._total_seqs = 0
        self._total_char = 0
        # characters that fall in our sampling range
        self._freq_char = 0

    @property
    def charset_name(self):
        if self._name_prober:
            return self._name_prober.charset_name
        else:
            return self._model['charset_name']

    @property
    def language(self):
        if self._name_prober:
            return self._name_prober.language
        else:
            return self._model.get('language')

    def feed(self, byte_str):
        if not self._model['keep_english_letter']:
            byte_str = self.filter_international_words(byte_str)
        if not byte_str:
            return self.state
        char_to_order_map = self._model['char_to_order_map']
        for i, c in enumerate(byte_str):
            # XXX: Order is in range 1-64, so one would think we want 0-63 here,
            #      but that leads to 27 more test failures than before.
            order = char_to_order_map[c]
            # XXX: This was SYMBOL_CAT_ORDER before, with a value of 250, but
            #      CharacterCategory.SYMBOL is actually 253, so we use CONTROL
            #      to make it closer to the original intent. The only difference
            #      is whether or not we count digits and control characters for
            #      _total_char purposes.
            if order < CharacterCategory.CONTROL:
                self._total_char += 1
            if order < self.SAMPLE_SIZE:
                self._freq_char += 1
                if self._last_order < self.SAMPLE_SIZE:
                    self._total_seqs += 1
                    if not self._reversed:
                        i = (self._last_order * self.SAMPLE_SIZE) + order
                        model = self._model['precedence_matrix'][i]
                    else:  # reverse the order of the letters in the lookup
                        i = (order * self.SAMPLE_SIZE) + self._last_order
                        model = self._model['precedence_matrix'][i]
                    self._seq_counters[model] += 1
            self._last_order = order

        charset_name = self._model['charset_name']
        if self.state == ProbingState.DETECTING:
            if self._total_seqs > self.SB_ENOUGH_REL_THRESHOLD:
                confidence = self.get_confidence()
                if confidence > self.POSITIVE_SHORTCUT_THRESHOLD:
                    self.logger.debug('%s confidence = %s, we have a winner',
                                      charset_name, confidence)
                    self._state = ProbingState.FOUND_IT
                elif confidence < self.NEGATIVE_SHORTCUT_THRESHOLD:
                    self.logger.debug('%s confidence = %s, below negative '
                                      'shortcut threshhold %s', charset_name,
                                      confidence,
                                      self.NEGATIVE_SHORTCUT_THRESHOLD)
                    self._state = ProbingState.NOT_ME

        return self.state

    def get_confidence(self):
        r = 0.01
        if self._total_seqs > 0:
            r = ((1.0 * self._seq_counters[SequenceLikelihood.POSITIVE]) /
                 self._total_seqs / self._model['typical_positive_ratio'])
            r = r * self._freq_char / self._total_char
            if r >= 1.0:
                r = 0.99
        return r

Filemanager

Name Type Size Permission Actions
cli Folder 0755
__init__.py File 1.52 KB 0644
__init__.pyc File 994 B 0644
__init__.pyo File 994 B 0644
big5freq.py File 30.52 KB 0644
big5freq.pyc File 53.42 KB 0644
big5freq.pyo File 53.42 KB 0644
big5prober.py File 1.72 KB 0644
big5prober.pyc File 1.33 KB 0644
big5prober.pyo File 1.33 KB 0644
chardistribution.py File 9.19 KB 0644
chardistribution.pyc File 7.67 KB 0644
chardistribution.pyo File 7.67 KB 0644
charsetgroupprober.py File 3.7 KB 0644
charsetgroupprober.pyc File 2.81 KB 0644
charsetgroupprober.pyo File 2.81 KB 0644
charsetprober.py File 4.99 KB 0644
charsetprober.pyc File 4.05 KB 0644
charsetprober.pyo File 4.05 KB 0644
codingstatemachine.py File 3.51 KB 0644
codingstatemachine.pyc File 3.28 KB 0644
codingstatemachine.pyo File 3.28 KB 0644
compat.py File 1.11 KB 0644
compat.pyc File 404 B 0644
compat.pyo File 404 B 0644
cp949prober.py File 1.81 KB 0644
cp949prober.pyc File 1.33 KB 0644
cp949prober.pyo File 1.33 KB 0644
enums.py File 1.62 KB 0644
enums.pyc File 3.06 KB 0644
enums.pyo File 3.06 KB 0644
escprober.py File 3.86 KB 0644
escprober.pyc File 3.16 KB 0644
escprober.pyo File 3.16 KB 0644
escsm.py File 10.26 KB 0644
escsm.pyc File 7.83 KB 0644
escsm.pyo File 7.83 KB 0644
eucjpprober.py File 3.66 KB 0644
eucjpprober.pyc File 2.97 KB 0644
eucjpprober.pyo File 2.97 KB 0644
euckrfreq.py File 13.23 KB 0644
euckrfreq.pyc File 23.52 KB 0644
euckrfreq.pyo File 23.52 KB 0644
euckrprober.py File 1.71 KB 0644
euckrprober.pyc File 1.33 KB 0644
euckrprober.pyo File 1.33 KB 0644
euctwfreq.py File 30.88 KB 0644
euctwfreq.pyc File 53.43 KB 0644
euctwfreq.pyo File 53.43 KB 0644
euctwprober.py File 1.71 KB 0644
euctwprober.pyc File 1.33 KB 0644
euctwprober.pyo File 1.33 KB 0644
gb2312freq.py File 20.23 KB 0644
gb2312freq.pyc File 37.45 KB 0644
gb2312freq.pyo File 37.45 KB 0644
gb2312prober.py File 1.71 KB 0644
gb2312prober.pyc File 1.34 KB 0644
gb2312prober.pyo File 1.34 KB 0644
hebrewprober.py File 13.51 KB 0644
hebrewprober.pyc File 3.72 KB 0644
hebrewprober.pyo File 3.72 KB 0644
jisfreq.py File 25.17 KB 0644
jisfreq.pyc File 43.45 KB 0644
jisfreq.pyo File 43.45 KB 0644
jpcntx.py File 19.18 KB 0644
jpcntx.pyc File 24.74 KB 0644
jpcntx.pyo File 24.74 KB 0644
langbulgarianmodel.py File 12.54 KB 0644
langbulgarianmodel.pyc File 24.38 KB 0644
langbulgarianmodel.pyo File 24.38 KB 0644
langcyrillicmodel.py File 17.53 KB 0644
langcyrillicmodel.pyc File 29.96 KB 0644
langcyrillicmodel.pyo File 29.96 KB 0644
langgreekmodel.py File 12.39 KB 0644
langgreekmodel.pyc File 24.06 KB 0644
langgreekmodel.pyo File 24.06 KB 0644
langhebrewmodel.py File 11.08 KB 0644
langhebrewmodel.pyc File 22.9 KB 0644
langhebrewmodel.pyo File 22.9 KB 0644
langhungarianmodel.py File 12.3 KB 0644
langhungarianmodel.pyc File 24.35 KB 0644
langhungarianmodel.pyo File 24.35 KB 0644
langthaimodel.py File 11.03 KB 0644
langthaimodel.pyc File 22.88 KB 0644
langthaimodel.pyo File 22.88 KB 0644
langturkishmodel.py File 10.84 KB 0644
langturkishmodel.pyc File 22.9 KB 0644
langturkishmodel.pyo File 22.9 KB 0644
latin1prober.py File 5.24 KB 0644
latin1prober.pyc File 3.65 KB 0644
latin1prober.pyo File 3.65 KB 0644
mbcharsetprober.py File 3.33 KB 0644
mbcharsetprober.pyc File 2.73 KB 0644
mbcharsetprober.pyo File 2.73 KB 0644
mbcsgroupprober.py File 1.96 KB 0644
mbcsgroupprober.pyc File 1.3 KB 0644
mbcsgroupprober.pyo File 1.3 KB 0644
mbcssm.py File 24.88 KB 0644
mbcssm.pyc File 18.67 KB 0644
mbcssm.pyo File 18.67 KB 0644
sbcharsetprober.py File 5.52 KB 0644
sbcharsetprober.pyc File 3.59 KB 0644
sbcharsetprober.pyo File 3.59 KB 0644
sbcsgroupprober.py File 3.46 KB 0644
sbcsgroupprober.pyc File 1.88 KB 0644
sbcsgroupprober.pyo File 1.88 KB 0644
sjisprober.py File 3.69 KB 0644
sjisprober.pyc File 3 KB 0644
sjisprober.pyo File 3 KB 0644
universaldetector.py File 12.19 KB 0644
universaldetector.pyc File 6.95 KB 0644
universaldetector.pyo File 6.95 KB 0644
utf8prober.py File 2.7 KB 0644
utf8prober.pyc File 2.46 KB 0644
utf8prober.pyo File 2.46 KB 0644
version.py File 242 B 0644
version.pyc File 431 B 0644
version.pyo File 431 B 0644