/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz

« back to all changes in this revision

Viewing changes to olive/backend/fileops.py

  • Committer: Jelmer Vernooij
  • Date: 2012-07-09 15:23:26 UTC
  • mto: This revision was merged to the branch mainline in revision 794.
  • Revision ID: jelmer@samba.org-20120709152326-dzxb8zoz0btull7n
Remove bzr-notify.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006 by Szilveszter Farkas (Phanatic) <szilveszter.farkas@gmail.com>
2
 
# Some parts of the code are:
3
 
# Copyright (C) 2005, 2006 by Canonical Ltd
4
 
 
5
 
# This program is free software; you can redistribute it and/or modify
6
 
# it under the terms of the GNU General Public License as published by
7
 
# the Free Software Foundation; either version 2 of the License, or
8
 
# (at your option) any later version.
9
 
 
10
 
# This program is distributed in the hope that it will be useful,
11
 
# but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 
# GNU General Public License for more details.
14
 
 
15
 
# You should have received a copy of the GNU General Public License
16
 
# along with this program; if not, write to the Free Software
17
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
18
 
 
19
 
import os
20
 
 
21
 
import bzrlib.errors as errors
22
 
 
23
 
from errors import (DirectoryAlreadyExists, MissingArgumentError,
24
 
                    MultipleMoveError, NoFilesSpecified, NoMatchingFiles,
25
 
                    NonExistingSource, NotBranchError, NotVersionedError)
26
 
 
27
 
def add(file_list, recursive=False):
28
 
    """ Add listed files to the branch. 
29
 
    
30
 
    :param file_list - list of files to be added (using full paths)
31
 
    
32
 
    :param recursive - if True, all unknown files will be added
33
 
    
34
 
    :return: count of ignored files
35
 
    """
36
 
    import bzrlib.add
37
 
    
38
 
    try:
39
 
        added, ignored = bzrlib.add.smart_add(file_list, recursive)
40
 
    except errors.NotBranchError:
41
 
        raise NotBranchError
42
 
    except:
43
 
        raise
44
 
    
45
 
    match_len = 0
46
 
    for glob, paths in ignored.items():
47
 
        match_len += len(paths)
48
 
    
49
 
    return match_len
50
 
 
51
 
def mkdir(directory):
52
 
    """ Create new versioned directory.
53
 
    
54
 
    :param directory: the full path to the directory to be created
55
 
    """
56
 
    from bzrlib.workingtree import WorkingTree
57
 
    
58
 
    try:
59
 
        os.mkdir(directory)
60
 
    except OSError, e:
61
 
        if e.errno == 17:
62
 
            raise DirectoryAlreadyExists(directory)
63
 
    else:
64
 
        wt, dd = WorkingTree.open_containing(directory)
65
 
        wt.add([dd])
66
 
 
67
 
def move(names_list):
68
 
    """ Move or rename given files.
69
 
    
70
 
    :param file_list: if two elements, then rename the first to the second, if more elements then move all of them to the directory specified in the last element
71
 
    """
72
 
    from bzrlib.builtins import tree_files
73
 
    
74
 
    if len(names_list) < 2:
75
 
        raise MissingArgumentError
76
 
    tree, rel_names = tree_files(names_list)
77
 
        
78
 
    if os.path.isdir(names_list[-1]):
79
 
        # move into existing directory
80
 
        for pair in tree.move(rel_names[:-1], rel_names[-1]):
81
 
            pass
82
 
    else:
83
 
        if len(names_list) != 2:
84
 
            raise MultipleMoveError
85
 
        tree.rename_one(rel_names[0], rel_names[1])
86
 
 
87
 
def remove(file_list, new=False):
88
 
    """ Make selected files unversioned.
89
 
    
90
 
    :param file_list: list of files/directories to be removed
91
 
    
92
 
    :param new: if True, the 'added' files will be removed
93
 
    """
94
 
    from bzrlib.builtins import tree_files
95
 
    
96
 
    try:
97
 
        tree, file_list = tree_files(file_list)
98
 
    except errors.NotBranchError:
99
 
        raise NotBranchError
100
 
    except:
101
 
        raise
102
 
    
103
 
    if new is False:
104
 
        if file_list is None:
105
 
            raise NoFilesSpecified
106
 
    else:
107
 
        from bzrlib.delta import compare_trees
108
 
        added = [compare_trees(tree.basis_tree(), tree,
109
 
                               specific_files=file_list).added]
110
 
        file_list = sorted([f[0] for f in added[0]], reverse=True)
111
 
        if len(file_list) == 0:
112
 
            raise NoMatchingFiles
113
 
    
114
 
    try:
115
 
        tree.remove(file_list)
116
 
    except errors.NotVersionedError:
117
 
        raise NotVersionedError
118
 
 
119
 
def rename(source, target):
120
 
    """ Rename a versioned file
121
 
    
122
 
    :param source: full path to the original file
123
 
    
124
 
    :param target: full path to the new file
125
 
    """
126
 
    if os.access(source, os.F_OK) is not True:
127
 
        raise NonExistingSource(source)
128
 
    
129
 
    move([source, target])
130
 
 
131
 
def status(filename):
132
 
    """ Get the status of a file.
133
 
    
134
 
    :param filename: the full path to the file
135
 
    
136
 
    :return: renamed | added | removed | modified | unchanged | unknown
137
 
    """
138
 
    from bzrlib.delta import compare_trees
139
 
    from bzrlib.workingtree import WorkingTree
140
 
    
141
 
    try:
142
 
        tree1 = WorkingTree.open_containing(filename)[0]
143
 
    except errors.NotBranchError:
144
 
        return 'unknown'
145
 
    
146
 
    branch = tree1.branch
147
 
    tree2 = tree1.branch.repository.revision_tree(branch.last_revision())
148
 
    
149
 
    # find the relative path to the given file (needed for proper delta)
150
 
    wtpath = tree1.basedir
151
 
    #print "DEBUG: wtpath =", wtpath
152
 
    fullpath = filename
153
 
    #print "DEBUG: fullpath =", fullpath
154
 
    i = 0
155
 
    wtsplit = wtpath.split('/')
156
 
    fpsplit = fullpath.split('/')
157
 
    fpcopy = fullpath.split('/')
158
 
    for item in fpsplit:
159
 
        if i is not len(wtsplit):
160
 
            if item == wtsplit[i]:
161
 
                del fpcopy[0]
162
 
            i = i + 1
163
 
    rel = '/'.join(fpcopy)
164
 
    #print "DEBUG: rel =", rel
165
 
    
166
 
    delta = compare_trees(old_tree=tree2,
167
 
                          new_tree=tree1,
168
 
                          want_unchanged=True,
169
 
                          specific_files=[rel])
170
 
    
171
 
    """ Debug information (could be usable in the future, so didn't cut out)
172
 
    print "DEBUG: delta.renamed:"
173
 
    for path, id, kind, text_modified, meta_modified in delta.renamed:
174
 
        print path
175
 
    print
176
 
    print "DEBUG: delta.added:"
177
 
    for path, id, kind in delta.added:
178
 
        print path
179
 
    print
180
 
    print "DEBUG: delta.removed:"
181
 
    for path, id, kind, text_modified, meta_modified in delta.removed:
182
 
        print path
183
 
    print
184
 
    print "DEBUG: delta.modified:"
185
 
    for path, id, kind, text_modified, meta_modified in delta.modified:
186
 
        print path
187
 
    print
188
 
    print "DEBUG: delta.unchanged:"
189
 
    for path, id, kind in delta.unchanged:
190
 
        print path
191
 
    """
192
 
    
193
 
    if len(delta.renamed):
194
 
        return 'renamed'
195
 
    elif len(delta.added):
196
 
        return 'added'
197
 
    elif len(delta.removed):
198
 
        return 'removed'
199
 
    elif len(delta.modified):
200
 
        return 'modified'
201
 
    elif len(delta.unchanged):
202
 
        return 'unchanged'
203
 
    else:
204
 
        return 'unknown'