tools: adding error and warning calls
[treecutter.git] / treecutter / tools.py
index a9c94a0837b7cf523ff17d40d1e361a027b75706..fa06a6d1272ab2e2abf757177098462b5ecdf366 100644 (file)
@@ -1,7 +1,9 @@
 #!/usr/bin/python
+from __future__ import print_function
 import os
 import subprocess
 import errno
+import sys
 
 def mkdir_p(path):
     try:
@@ -15,7 +17,7 @@ def publish(src,target):
     cmd = ["rsync","-a","--delete",src,target]
     retcode = subprocess.call(cmd)
     if retcode:
-        print 'Error: '+' '.join(cmd)+' Returncode ['+str(retcode)+']'
+        error('%s : retruncode %s' % (' '.join(cmd),str(retcode)))
 
 def ssh_cmd(target, command):
     t = target.split(":")
@@ -26,4 +28,27 @@ def ssh_cmd(target, command):
         cmd = ["ssh",t[0],c[0],c[1],t[1]]
     retcode = subprocess.call(cmd)
     if retcode:
-        print 'Error: '+' '.join(cmd)+' Returncode ['+str(retcode)+']'
+        error('%s : retruncode %s' % (' '.join(cmd),str(retcode)))
+
+def sizeof_fmt(num, suffix='B'):
+    for unit in ['','Ki','Mi','Gi','Ti','Pi','Ei','Zi']:
+        if abs(num) < 1024.0:
+            return "%3.1f%s%s" % (num, unit, suffix)
+        num /= 1024.0
+    return "%.1f%s%s" % (num, 'Yi', suffix)
+
+def get_folder_size(folder):
+    total_size = os.path.getsize(folder)
+    for item in os.listdir(folder):
+        itempath = os.path.join(folder, item)
+        if os.path.isfile(itempath):
+            total_size += os.path.getsize(itempath)
+        elif os.path.isdir(itempath):
+            total_size += get_folder_size(itempath)
+    return total_size
+
+def warning(*objs):
+    print("WARNING: ", *objs, file=sys.stderr)
+
+def error(*objs):
+    print("ERROR: ", *objs, file=sys.stderr)