You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

139 lines
4.7 KiB

14 years ago
# -*- coding: utf-8 -*-
13 years ago
# Copyright 2011-2012 Antoine Bertin <diaoulael@gmail.com>
14 years ago
#
13 years ago
# This file is part of subliminal.
14 years ago
#
13 years ago
# subliminal is free software; you can redistribute it and/or modify it under
# the terms of the GNU Lesser General Public License as published by
14 years ago
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
#
13 years ago
# subliminal is distributed in the hope that it will be useful,
14 years ago
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 years ago
# GNU Lesser General Public License for more details.
14 years ago
#
13 years ago
# You should have received a copy of the GNU Lesser General Public License
# along with subliminal. If not, see <http://www.gnu.org/licenses/>.
13 years ago
from .language import Language
13 years ago
import os.path
14 years ago
13 years ago
__all__ = ['Subtitle', 'EmbeddedSubtitle', 'ExternalSubtitle', 'ResultSubtitle', 'get_subtitle_path']
14 years ago
13 years ago
#: Subtitles extensions
14 years ago
EXTENSIONS = ['.srt', '.sub', '.txt']
class Subtitle(object):
13 years ago
"""Base class for subtitles
:param string path: path to the subtitle
13 years ago
:param language: language of the subtitle
13 years ago
:type language: :class:`~subliminal.language.Language`
14 years ago
13 years ago
"""
14 years ago
def __init__(self, path, language):
self.path = path
self.language = language
@property
def exists(self):
13 years ago
"""Whether the subtitle exists or not"""
14 years ago
if self.path:
return os.path.exists(self.path)
return False
class EmbeddedSubtitle(Subtitle):
13 years ago
"""Subtitle embedded in a container
:param string path: path to the subtitle
13 years ago
:param language: language of the subtitle
13 years ago
:type language: :class:`~subliminal.language.Language`
13 years ago
:param int track_id: id of the subtitle track in the container
"""
14 years ago
def __init__(self, path, language, track_id):
super(EmbeddedSubtitle, self).__init__(path, language)
self.track_id = track_id
@classmethod
13 years ago
def from_enzyme(cls, path, subtitle):
13 years ago
language = Language(subtitle.language) or None
14 years ago
return cls(path, language, subtitle.trackno)
class ExternalSubtitle(Subtitle):
13 years ago
"""Subtitle in a file next to the video file"""
@classmethod
def from_path(cls, path):
"""Create an :class:`ExternalSubtitle` from path"""
extension = ''
for e in EXTENSIONS:
if path.endswith(e):
extension = e
break
if not extension:
raise ValueError('Not a supported subtitle extension')
language = os.path.splitext(path[:len(path) - len(extension)])[1][1:]
13 years ago
language = Language(language) or None
13 years ago
return cls(path, language)
14 years ago
class ResultSubtitle(ExternalSubtitle):
13 years ago
"""Subtitle found using :mod:`~subliminal.services`
:param string path: path to the subtitle
13 years ago
:param language: language of the subtitle
13 years ago
:type language: :class:`~subliminal.language.Language`
13 years ago
:param string service: name of the service
:param string link: download link for the subtitle
:param string release: release name of the video
:param float confidence: confidence that the subtitle matches the video according to the service
:param set keywords: keywords that describe the subtitle
"""
def __init__(self, path, language, service, link, release=None, confidence=1, keywords=set()):
14 years ago
super(ResultSubtitle, self).__init__(path, language)
13 years ago
self.service = service
14 years ago
self.link = link
self.release = release
self.confidence = confidence
self.keywords = keywords
@property
def single(self):
13 years ago
"""Whether this is a single subtitle or not. A single subtitle does not have
a language indicator in its file name
:rtype: bool
"""
14 years ago
extension = os.path.splitext(self.path)[0]
language = os.path.splitext(self.path[:len(self.path) - len(extension)])[1][1:]
13 years ago
return Language(language) == Language('und')
14 years ago
13 years ago
def __repr__(self):
return 'ResultSubtitle(%s, %s, %.2f, %s)' % (self.language, self.service, self.confidence, self.release)
14 years ago
def get_subtitle_path(video_path, language, multi):
13 years ago
"""Create the subtitle path from the given video path using language if multi
:param string video_path: path to the video
:param language: language of the subtitle
13 years ago
:type language: :class:`~subliminal.language.Language`
13 years ago
:param bool multi: whether to use multi language naming or not
:return: path of the subtitle
:rtype: string
"""
14 years ago
if not os.path.exists(video_path):
path = os.path.splitext(os.path.basename(video_path))[0]
else:
path = os.path.splitext(video_path)[0]
if multi and language:
13 years ago
return path + '.%s%s' % (language.alpha2, EXTENSIONS[0])
14 years ago
return path + '%s' % EXTENSIONS[0]