2007-06-24 14:52:46 +02:00
|
|
|
# Copyright (C) 2006-2007, Red Hat, Inc.
|
2007-08-16 21:41:42 +02:00
|
|
|
# Copyright (C) 2007, One Laptop Per Child
|
2007-06-24 14:52:46 +02:00
|
|
|
#
|
|
|
|
# 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 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., 59 Temple Place - Suite 330,
|
|
|
|
# Boston, MA 02111-1307, USA.
|
|
|
|
|
2007-07-14 13:53:49 +02:00
|
|
|
import logging
|
|
|
|
|
2007-06-29 22:11:28 +02:00
|
|
|
from sugar import _sugarext
|
2007-05-24 12:30:42 +02:00
|
|
|
|
|
|
|
def get_for_file(file_name):
|
2007-08-16 21:41:42 +02:00
|
|
|
mime_type = _sugarext.get_mime_type_for_file(file_name)
|
|
|
|
if mime_type == 'application/octet-stream':
|
|
|
|
if _file_looks_like_text(file_name):
|
|
|
|
return 'text/plain'
|
|
|
|
else:
|
|
|
|
return 'application/octet-stream'
|
|
|
|
return mime_type
|
2007-05-24 12:30:42 +02:00
|
|
|
|
2007-05-24 12:08:05 +02:00
|
|
|
def get_from_file_name(file_name):
|
|
|
|
return _sugarext.get_mime_type_from_file_name(file_name)
|
2007-06-21 13:07:11 +02:00
|
|
|
|
|
|
|
_extensions_cache = {}
|
|
|
|
def get_primary_extension(mime_type):
|
|
|
|
if _extensions_cache.has_key(mime_type):
|
|
|
|
return _extensions_cache[mime_type]
|
|
|
|
|
|
|
|
f = open('/etc/mime.types')
|
|
|
|
while True:
|
|
|
|
line = f.readline()
|
|
|
|
cols = line.replace('\t', ' ').split(' ')
|
|
|
|
if mime_type == cols[0]:
|
|
|
|
for col in cols[1:]:
|
|
|
|
if col:
|
|
|
|
_extensions_cache[mime_type] = col
|
|
|
|
return col
|
|
|
|
|
|
|
|
_extensions_cache[mime_type] = None
|
|
|
|
return None
|
2007-07-14 13:53:49 +02:00
|
|
|
|
|
|
|
def choose_most_significant(mime_types):
|
|
|
|
logging.debug('Choosing between %r.' % mime_types)
|
|
|
|
if not mime_types:
|
|
|
|
return ''
|
|
|
|
|
|
|
|
if 'text/uri-list' in mime_types:
|
|
|
|
return 'text/uri-list'
|
|
|
|
|
|
|
|
for mime_category in ['image/', 'text/', 'application/']:
|
|
|
|
for mime_type in mime_types:
|
|
|
|
|
|
|
|
# skip text/plain and text/html, these have lower priority.
|
|
|
|
if mime_type in ['text/plain', 'text/html']:
|
|
|
|
continue
|
|
|
|
|
|
|
|
if mime_type.startswith(mime_category):
|
2007-07-28 16:00:32 +02:00
|
|
|
# skip mozilla private types (second component starts with '_'
|
|
|
|
# or ends with '-priv')
|
|
|
|
if mime_type.split('/')[1].startswith('_') or \
|
|
|
|
mime_type.split('/')[1].endswith('-priv'):
|
2007-07-14 13:53:49 +02:00
|
|
|
continue
|
|
|
|
|
|
|
|
# take out the specifier after ';' that mozilla likes to add
|
|
|
|
mime_type = mime_type.split(';')[0]
|
|
|
|
logging.debug('Choosed %r!' % mime_type)
|
|
|
|
return mime_type
|
|
|
|
|
|
|
|
if 'text/html' in mime_types:
|
2007-07-28 16:00:32 +02:00
|
|
|
logging.debug('Choosed text/html!')
|
2007-07-14 13:53:49 +02:00
|
|
|
return 'text/html'
|
|
|
|
|
|
|
|
if 'text/plain' in mime_types or 'STRING' in mime_types:
|
2007-07-28 16:00:32 +02:00
|
|
|
logging.debug('Choosed text/plain!')
|
2007-07-14 13:53:49 +02:00
|
|
|
return 'text/plain'
|
|
|
|
|
|
|
|
logging.debug('Returning first: %r.' % mime_types[0])
|
|
|
|
return mime_types[0]
|
2007-08-16 21:41:42 +02:00
|
|
|
|
|
|
|
def _file_looks_like_text(file_name):
|
|
|
|
f = open(file_name, 'r')
|
|
|
|
try:
|
|
|
|
sample = f.read(256)
|
|
|
|
finally:
|
|
|
|
f.close()
|
|
|
|
|
|
|
|
if '\000' in sample:
|
|
|
|
return False
|
|
|
|
|
|
|
|
for encoding in ('ascii', 'latin_1', 'utf_8', 'utf_16'):
|
|
|
|
try:
|
|
|
|
string = unicode(sample, encoding)
|
|
|
|
return True
|
|
|
|
except Exception, e:
|
|
|
|
pass
|
|
|
|
|
|
|
|
return False
|