/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to tools/win32/file_version.py

  • Committer: Vincent Ladeuil
  • Date: 2009-01-23 21:06:48 UTC
  • mto: (3966.1.1 bzr.integration)
  • mto: This revision was merged to the branch mainline in revision 3967.
  • Revision ID: v.ladeuil+lp@free.fr-20090123210648-yfb39g22yyo83d3y
Slight refactoring and test fixing.

* bzrlib/tests/test_merge.py:
(TestMergerEntriesLCAOnDisk.test_modified_symlink): Passing now.

* bzrlib/merge.py:
(Merge3Merger._lca_multi_way): Fix doc reference.
(Merge3Merger.merge_contents.contents_conflict): Try to delay
this_pair evaulation to avoid unnecessary sha1 (impyling file read
from disk) calculation. Also slightly refactor to avoid repeated
file_id in trees calculations.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#!/usr/bin/python
 
2
 
 
3
"""Get file version.
 
4
Written by Alexander Belchenko, 2006
 
5
"""
 
6
 
 
7
import os
 
8
 
 
9
import pywintypes   # from pywin32 (http://pywin32.sf.net)
 
10
import win32api     # from pywin32 (http://pywin32.sf.net)
 
11
 
 
12
 
 
13
__all__ = ['get_file_version', 'FileNotFound', 'VersionNotAvailable']
 
14
__docformat__ = "restructuredtext"
 
15
 
 
16
 
 
17
class FileNotFound(Exception):
 
18
    pass
 
19
 
 
20
class VersionNotAvailable(Exception):
 
21
    pass
 
22
 
 
23
 
 
24
def get_file_version(filename):
 
25
    """Get file version (windows properties)
 
26
    :param  filename:   path to file
 
27
    :return:            4-tuple with 4 version numbers
 
28
    """
 
29
    if not os.path.isfile(filename):
 
30
        raise FileNotFound
 
31
 
 
32
    try:
 
33
        version_info = win32api.GetFileVersionInfo(filename, '\\')
 
34
    except pywintypes.error:
 
35
        raise VersionNotAvailable
 
36
 
 
37
    return (divmod(version_info['FileVersionMS'], 65536) +
 
38
            divmod(version_info['FileVersionLS'], 65536))