~ubuntu-branches/ubuntu/karmic/calibre/karmic

« back to all changes in this revision

Viewing changes to src/calibre/ebooks/metadata/txt.py

  • Committer: Bazaar Package Importer
  • Author(s): Martin Pitt
  • Date: 2009-07-30 12:49:41 UTC
  • mfrom: (1.3.2 upstream)
  • Revision ID: james.westby@ubuntu.com-20090730124941-qjdsmri25zt8zocn
Tags: 0.6.3+dfsg-0ubuntu1
* New upstream release. Please see http://calibre.kovidgoyal.net/new_in_6/
  for the list of new features and changes.
* remove_postinstall.patch: Update for new version.
* build_debug.patch: Does not apply any more, disable for now. Might not be
  necessary any more.
* debian/copyright: Fix reference to versionless GPL.
* debian/rules: Drop obsolete dh_desktop call.
* debian/rules: Add workaround for weird Python 2.6 setuptools behaviour of
  putting compiled .so files into src/calibre/plugins/calibre/plugins
  instead of src/calibre/plugins.
* debian/rules: Drop hal fdi moving, new upstream version does not use hal
  any more. Drop hal dependency, too.
* debian/rules: Install udev rules into /lib/udev/rules.d.
* Add debian/calibre.preinst: Remove unmodified
  /etc/udev/rules.d/95-calibre.rules on upgrade.
* debian/control: Bump Python dependencies to 2.6, since upstream needs
  it now.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
'''Read meta information from TXT files'''
 
2
 
 
3
from __future__ import with_statement
 
4
 
 
5
__license__   = 'GPL v3'
 
6
__copyright__ = '2009, John Schember <john@nachtimwald.com>'
 
7
 
 
8
import re
 
9
 
 
10
from calibre.ebooks.metadata import MetaInformation
 
11
 
 
12
def get_metadata(stream, extract_cover=True):
 
13
    """ Return metadata as a L{MetaInfo} object """
 
14
    mi = MetaInformation(_('Unknown'), [_('Unknown')])
 
15
    stream.seek(0)
 
16
 
 
17
    mdata = u''
 
18
    for x in range(0, 4):
 
19
        line = stream.readline().decode('utf-8')
 
20
        if line == '':
 
21
            break
 
22
        else:
 
23
            mdata += line
 
24
    
 
25
    mo = re.search('(?u)^[ ]*(?P<title>.+)[ ]*(\n{3}|(\r\n){3}|\r{3})[ ]*(?P<author>.+)[ ]*(\n|\r\n|\r)$', mdata)
 
26
    if mo != None:
 
27
        mi.title = mo.group('title')
 
28
        mi.authors = mo.group('author').split(',')
 
29
 
 
30
    return mi