annotate gcp @ 4:9feb82bd91aa

--preserve option (same default as for cp) & progress bar are now working. also added --force & --verbose options
author Goffi <goffi@goffi.org>
date Sun, 26 Sep 2010 14:08:14 +0800
parents 6a24b5928980
children 7edbb0e0d9dd
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
1 #!/usr/bin/python
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
2 # -*- coding: utf-8 -*-
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
3
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
4 """
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
5 gcp: Goffi's CoPier
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
6 Copyright (C) 2010 Jérôme Poisson (goffi@goffi.org)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
7
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
8 This program is free software: you can redistribute it and/or modify
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
9 it under the terms of the GNU General Public License as published by
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
10 the Free Software Foundation, either version 3 of the License, or
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
11 (at your option) any later version.
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
12
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
13 This program is distributed in the hope that it will be useful,
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
16 GNU General Public License for more details.
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
17
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
19 along with this program. If not, see <http://www.gnu.org/licenses/>.
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
20 """
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
21
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
22 ### logging ###
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
23 import logging
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
24 from logging import debug, info, error, warning
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
25 logging.basicConfig(level=logging.INFO,
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
26 format='%(message)s')
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
27 ###
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
28 import sys
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
29 import os,os.path
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
30 from optparse import OptionParser #To be replaced by argparse ASAP
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
31 import cPickle as pickle
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
32 try:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
33 import gobject
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
34 #DBus
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
35 import dbus, dbus.glib
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
36 import dbus.service
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
37 import dbus.mainloop.glib
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
38 except ImportError,e:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
39 error("Error during import")
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
40 error("Please check dependecies:",e)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
41 exit(2)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
42 try:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
43 from progressbar import ProgressBar, Percentage, Bar, ETA, FileTransferSpeed
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
44 pbar_available=True
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
45 except ImportError, e:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
46 info ('ProgressBar not available, please download it at http://pypi.python.org/pypi/progressbar')
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
47 info ('Progress bar deactivated\n--\n')
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
48 pbar_available=False
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
49
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
50 NAME = "gcp (Goffi's copier)"
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
51 NAME_SHORT = "gcp"
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
52 VERSION = '0.1'
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
53
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
54 ABOUT = NAME+" v"+VERSION+""" (c) Jérôme Poisson (aka Goffi) 2010
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
55
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
56 ---
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
57 """+NAME+""" Copyright (C) 2010 Jérôme Poisson
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
58 This program comes with ABSOLUTELY NO WARRANTY;
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
59 This is free software, and you are welcome to redistribute it
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
60 under certain conditions.
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
61 ---
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
62
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
63 This software is an advanced file copier
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
64 Get the latest version at http://www.goffi.org
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
65 """
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
66
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
67 const_DBUS_INTERFACE = "org.goffi.gcp"
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
68 const_DBUS_PATH = "/org/goffi/gcp"
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
69 const_BUFF_SIZE = 4096
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
70 const_PRESERVE = set(['mode','ownership','timestamps'])
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
71
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
72
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
73 class DbusObject(dbus.service.Object):
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
74
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
75 def __init__(self, gcp, bus, path):
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
76 self._gcp = gcp
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
77 dbus.service.Object.__init__(self, bus, path)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
78 debug("Init DbusObject...")
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
79 self.cb={}
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
80
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
81 @dbus.service.method(const_DBUS_INTERFACE,
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
82 in_signature='', out_signature='s')
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
83 def getVersion(self):
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
84 """Get gcp version
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
85 @return: version as string"""
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
86 return VERSION
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
87
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
88 @dbus.service.method(const_DBUS_INTERFACE,
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
89 in_signature='ss', out_signature='bs')
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
90 def addArgs(self, source_path, args):
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
91 """Add arguments to gcp as if there were entered on its own command line
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
92 @param source_path: current working dir to use as base for arguments, as given by os.getcwd()
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
93 @param args: serialized (wich pickle) list of strings - without command name -, as given by sys.argv[1:].
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
94 @return: success (boolean) and error message if any (string)"""
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
95 try:
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
96 args = pickle.loads(str(args))
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
97 except TypeError, pickle.UnpicklingError:
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
98 return (False, "INTERNAL ERROR: invalid arguments")
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
99 return self._gcp.parseArguments(args, source_path)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
100
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
101 class GCP():
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
102
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
103 def __init__(self):
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
104 try:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
105 sessions_bus = dbus.SessionBus()
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
106 db_object = sessions_bus.get_object(const_DBUS_INTERFACE,
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
107 const_DBUS_PATH)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
108 self.gcp_main = dbus.Interface(db_object,
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
109 dbus_interface=const_DBUS_INTERFACE)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
110 self._main_instance = False
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
111
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
112 except dbus.exceptions.DBusException,e:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
113 if e._dbus_error_name=='org.freedesktop.DBus.Error.ServiceUnknown':
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
114 self.launchDbusMainInstance()
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
115 debug ("gcp launched")
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
116 self._main_instance = True
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
117 self.buffer_size = const_BUFF_SIZE
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
118 else:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
119 raise e
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
120
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
121 def launchDbusMainInstance(self):
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
122 debug ("Init DBus...")
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
123 session_bus = dbus.SessionBus()
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
124 self.dbus_name = dbus.service.BusName(const_DBUS_INTERFACE, session_bus)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
125 self.dbus_object = DbusObject(self, session_bus, const_DBUS_PATH)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
126
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
127 self.copy_list = []
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
128 self.mounts = self.__getMountPoints()
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
129 self.files_left = 0
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
130 self.bytes_total = 0
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
131 self.bytes_copied = 0
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
132
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
133 def getFsType(self, path):
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
134 fs=''
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
135 for mount in self.mounts:
2
1b91aa4f3c85 getFsType fix
Goffi <goffi@goffi.org>
parents: 1
diff changeset
136 if path.startswith(mount) and len(self.mounts[mount])>=len(fs):
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
137 fs = self.mounts[mount]
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
138 return fs
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
139
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
140 def __getMountPoints(self):
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
141 """Parse /proc/mounts to get currently mounted devices"""
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
142 #TODO: reparse when a new device is added/a device is removed
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
143 #(check freedesktop mounting signals)
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
144 ret = {}
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
145 try:
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
146 with open("/proc/mounts",'rb') as mounts:
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
147 for line in mounts.readlines():
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
148 fs_spec, fs_file, fs_vfstype, fs_mntops, fs_freq, fs_passno = line.split(' ')
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
149 ret[fs_file] = fs_vfstype
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
150 except:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
151 error ("Can't read mounts table")
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
152 return ret
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
153
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
154 def __appendToList(self, path, dest_path, options):
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
155 """Add a file to the copy list
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
156 @param path: absolute path of file
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
157 @param options: options as return by optparse"""
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
158 debug ("Adding to copy list: %s ==> %s (%s)", path, dest_path, self.getFsType(dest_path))
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
159 try:
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
160 self.bytes_total+=os.path.getsize(path)
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
161 self.files_left+=1
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
162 self.copy_list.insert(0,(path, dest_path, options))
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
163 except OSError,e:
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
164 error("Can't copy %(path)s: %(exception)s" % {'path':path, 'exception':e.strerror})
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
165
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
166
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
167 def __appendDirToList(self, dirpath, dest_path, options):
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
168 """Add recursively directory to the copy list
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
169 @param path: absolute path of dir
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
170 @param options: options as return by optparse"""
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
171 #We first check that the dest path exists, and create it if needed
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
172 if not os.path.exists(dest_path):
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
173 debug ("Creating directory %s" % dest_path)
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
174 os.makedirs(dest_path) #TODO: check permissions
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
175 #TODO: check that dest_path is an accessible dir,
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
176 # and skip file/write error in log if needed
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
177 try:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
178 for filename in os.listdir(dirpath):
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
179 filepath = os.path.join(dirpath,filename)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
180 if os.path.isdir(filepath):
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
181 full_dest_path = os.path.join(dest_path,filename)
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
182 self.__appendDirToList(filepath, full_dest_path, options)
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
183 else:
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
184 self.__appendToList(filepath, dest_path, options)
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
185 except OSError,e:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
186 error("Can't copy %(path)s: %(exception)s" % {'path':dirpath, 'exception':e.strerror})
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
187
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
188 def __checkArgs(self, options, source_path, args):
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
189 """Check thats args are files, and add them to copy list"""
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
190 assert(len (args)>=2)
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
191 try:
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
192 dest_path = os.path.normpath(os.path.join(os.path.expanduser(source_path), args.pop()))
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
193 except OSError,e:
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
194 error ("Invalid dest_path: %s",e)
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
195
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
196 for path in args:
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
197 abspath = os.path.normpath(os.path.join(os.path.expanduser(source_path), path))
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
198 if not os.path.exists(abspath):
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
199 warning("The path given in arg doesn't exist or is not accessible: %s",abspath)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
200 else:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
201 if os.path.isdir(abspath):
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
202 full_dest_path = dest_path if os.path.isabs(path) else os.path.normpath(os.path.join(dest_path, path))
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
203 if not options.recursive:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
204 warning ('omitting directory "%s"' % abspath)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
205 else:
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
206 self.__appendDirToList(abspath, full_dest_path, options)
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
207 else:
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
208 self.__appendToList(abspath, dest_path, options)
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
209
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
210 def __copyNextFile(self):
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
211 """Take the last file in the list, and launch the copy using glib io_watch event
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
212 @return: True a file was added, False else"""
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
213 if self.copy_list:
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
214 source_file, dest_path, options = self.copy_list.pop()
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
215 source_fd = open(source_file, 'rb')
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
216 filename = os.path.basename(source_file)
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
217 assert(filename)
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
218 dest_file = os.path.join(dest_path,filename)
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
219 if os.path.exists(dest_file) and not options.force:
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
220 warning ("File [%s] already exists, skipping it !" % dest_file)
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
221 return True
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
222 dest_fd = open(dest_file, 'wb')
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
223
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
224 gobject.io_add_watch(source_fd,gobject.IO_IN,self._copyFile,
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
225 (dest_fd, options), priority=gobject.PRIORITY_HIGH)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
226 if not self.progress:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
227 info("COPYING %(source)s ==> %(dest)s" % {"source":source_path,"dest":dest_file})
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
228 return True
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
229 else:
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
230 #Nothing left to copy, we quit
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
231 if self.progress:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
232 self.__pbar_finish()
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
233 self.loop.quit()
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
234
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
235 def _copyFile(self, source_fd, condition, data):
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
236 """Actually copy the file, callback used with io_add_watch
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
237 @param source_fd: file descriptor of the file to copy
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
238 @param condition: condition which launched the callback (glib.IO_IN)
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
239 @param data: tuple with (destination file descriptor, copying options)"""
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
240 dest_fd,options = data
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
241 buff = source_fd.read(self.buffer_size)
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
242 dest_fd.write(buff)
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
243 self.bytes_copied += len(buff)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
244 if self.progress:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
245 self.__pbar_update()
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
246
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
247 if len(buff) != self.buffer_size:
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
248 source_fd.close()
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
249 dest_fd.close()
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
250 self.__post_copy(source_fd.name, dest_fd.name, options)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
251 self.files_left -= 1
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
252 assert (self.files_left >= 0)
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
253 return False
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
254 return True
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
255
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
256 def __post_copy(self, source_file, dest_file, options):
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
257 """Do post copy traitement (mainly managing --preserve option)"""
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
258 st_mode, st_ino, st_dev, st_nlink, st_uid, st_gid, st_size, st_atime, st_mtime, st_ctime = os.stat(source_file)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
259 #TODO: complete log in case of errors
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
260 for preserve in options.preserve:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
261 try:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
262 if preserve == 'mode':
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
263 os.chmod(dest_file, st_mode)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
264 elif preserve == 'ownership':
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
265 os.chown(dest_file, st_uid, st_gid)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
266 elif preserve == 'timestamps':
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
267 os.utime(dest_file, (st_atime, st_mtime))
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
268 except OSError,e:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
269 pass #TODO: complete log here
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
270
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
271 def __pbar_update(self):
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
272 """Update progress bar position, create the bar if it doesn't exist"""
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
273 assert(self.progress)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
274 try:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
275 if self.pbar.maxval != self.bytes_total:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
276 self.pbar.maxval = self.bytes_total
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
277 except AttributeError:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
278 self.pbar = ProgressBar(self.bytes_total,["Progress: ",Percentage()," ",Bar()," ",FileTransferSpeed()," ",ETA()])
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
279 self.pbar.start()
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
280 self.pbar.update(self.bytes_copied)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
281
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
282 def __pbar_finish(self):
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
283 """Mark the progression as finished"""
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
284 assert(self.progress)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
285 try:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
286 self.pbar.finish()
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
287 except AttributeError:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
288 pass
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
289
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
290 def parseArguments(self, full_args=sys.argv[1:], source_path = os.getcwd()):
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
291 """Parse arguments and add files to queue
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
292 @param full_args: list of arguments strings (without program name)
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
293 @param source_path: path from where the arguments come, ad given by os.getcwd()
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
294 @return: a tuple (boolean, message) where the boolean is the success of the arguments
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
295 validation, and message is the error message to print when necessary"""
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
296 _usage="""
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
297 %prog [options] FILE1 [FILE2 ...] DEST
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
298
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
299 %prog --help for options list
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
300 """
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
301 for idx in range(len(full_args)):
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
302 if isinstance(full_args[idx], unicode):
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
303 #We don't want unicode as some filenames can be invalid unicode
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
304 full_args[idx] = full_args[idx].encode('utf-8')
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
305
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
306 parser = OptionParser(usage=_usage,version=ABOUT)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
307
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
308 parser.add_option("-r", "--recursive", action="store_true", default=False,
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
309 help="copy directories recursively")
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
310
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
311 parser.add_option("-f", "--force", action="store_true", default=False,
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
312 help="force overwriting of existing files")
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
313
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
314 parser.add_option("--preserve", action="store", default='mode,ownership,timestamps',
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
315 help="preserve the specified attributes")
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
316
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
317 parser.add_option("--no-unicode-fix", action="store_true", default=False,
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
318 help="don't fixe name encoding errors") #TODO
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
319
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
320 parser.add_option("--no-progress", action="store_false", dest="progress", default=True,
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
321 help="deactivate progress bar")
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
322
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
323 parser.add_option("-v", "--verbose", action="store_true", default=False,
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
324 help="Show what is currently done")
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
325
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
326 (options, args) = parser.parse_args(full_args)
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
327 #options check
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
328 if options.progress and not pbar_available:
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
329 warning ("Progress bar is not available, deactivating")
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
330 options.progress = self.progress = False
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
331 else:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
332 self.progress = options.progress
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
333
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
334 if options.verbose:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
335 logging.getLogger().setLevel(logging.DEBUG)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
336
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
337 preserve = set(options.preserve.split(','))
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
338 if not preserve.issubset(const_PRESERVE):
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
339 error ('Invalide --preserve value\nvalid values are:')
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
340 for value in const_PRESERVE:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
341 error('- %s' % value)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
342 exit(2)
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
343 else:
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
344 options.preserve = preserve
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
345
4
9feb82bd91aa --preserve option (same default as for cp) & progress bar are now working.
Goffi <goffi@goffi.org>
parents: 3
diff changeset
346 #if there is an other instance of gcp, we send options to it
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
347 if not self._main_instance:
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
348 info ("There is already one instance of %s running, pluging to it" % NAME_SHORT)
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
349 #XXX: we have to serialize data as dbus only accept valid unicode, and filenames
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
350 # can have invalid unicode.
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
351 return self.gcp_main.addArgs(os.getcwd(),pickle.dumps(full_args))
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
352 else:
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
353 if len(args) < 2:
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
354 _error_msg = "Wrong number of arguments"
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
355 return (False, _error_msg)
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
356 debug("adding args to gcp: %s",args)
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
357 self.__checkArgs(options, source_path, args)
3
6a24b5928980 Basic file copying
Goffi <goffi@goffi.org>
parents: 2
diff changeset
358 gobject.idle_add(self.__copyNextFile)
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
359 return (True,'')
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
360
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
361 def go(self):
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
362 """Launch main loop"""
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
363 self.loop = gobject.MainLoop()
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
364 try:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
365 self.loop.run()
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
366 except KeyboardInterrupt:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
367 info("User interruption: good bye")
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
368
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
369
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
370 if __name__ == "__main__":
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
371 gcp = GCP()
1
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
372 success,message = gcp.parseArguments()
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
373 if not success:
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
374 error(message)
995487813501 Arguments management
Goffi <goffi@goffi.org>
parents: 0
diff changeset
375 exit(1)
0
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
376 if gcp._main_instance:
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
377 gcp.go()
674ce820a4ef initial commit
Goffi <goffi@goffi.org>
parents:
diff changeset
378