2020-08-11 03:51:51 +00:00
|
|
|
import send2trash
|
2021-09-24 06:42:34 +00:00
|
|
|
import sys
|
2020-08-11 03:51:51 +00:00
|
|
|
|
2022-11-11 23:11:08 +00:00
|
|
|
from voussoirkit import bytestring
|
2021-09-24 06:42:34 +00:00
|
|
|
from voussoirkit import pathclass
|
2020-12-06 23:02:56 +00:00
|
|
|
from voussoirkit import pipeable
|
2022-11-11 23:11:08 +00:00
|
|
|
from voussoirkit import vlogging
|
2020-08-11 03:51:51 +00:00
|
|
|
|
2022-11-11 23:11:08 +00:00
|
|
|
log = vlogging.get_logger(__name__, 'recycle')
|
|
|
|
|
|
|
|
@vlogging.main_decorator
|
2021-09-24 06:42:34 +00:00
|
|
|
def main(argv):
|
2022-11-11 23:11:08 +00:00
|
|
|
count = 0
|
|
|
|
total_bytes = 0
|
2021-09-24 06:42:34 +00:00
|
|
|
for path in pathclass.glob_many(pipeable.go(argv, skip_blank=True)):
|
|
|
|
pipeable.stdout(path.absolute_path)
|
2022-01-04 20:43:37 +00:00
|
|
|
try:
|
2022-11-11 23:11:08 +00:00
|
|
|
this_bytes = path.size
|
2022-01-04 20:43:37 +00:00
|
|
|
send2trash.send2trash(path)
|
|
|
|
except Exception as exc:
|
2022-11-11 23:11:08 +00:00
|
|
|
message = f'Recycling {path.absolute_path} caused an exception:\n{exc}'
|
|
|
|
log.error(message)
|
2022-01-04 20:43:37 +00:00
|
|
|
return 1
|
2022-11-11 23:11:08 +00:00
|
|
|
else:
|
|
|
|
count += 1
|
|
|
|
total_bytes += this_bytes
|
|
|
|
log.info(f'Recycled {count} files totaling {bytestring.bytestring(total_bytes)}.')
|
2021-09-24 06:42:34 +00:00
|
|
|
return 0
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
raise SystemExit(main(sys.argv[1:]))
|