Passed
Pull Request — main (#107)
by
unknown
01:10
created

pyclean.runner.print_dirname()   A

Complexity

Conditions 1

Size

Total Lines 3
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 3
dl 0
loc 3
rs 10
c 0
b 0
f 0
cc 1
nop 1
1
# SPDX-FileCopyrightText: 2020 Peter Bittner <[email protected]>
2
#
3
# SPDX-License-Identifier: GPL-3.0-or-later
4
5
import logging
6
7
log = logging.getLogger(__name__)
8
9
10
class CleanupRunner:
11
12
    def __init__(self):
13
        self.unlink = None
14
        self.rmdir = None
15
        self.ignore = None
16
        self.unlink_count = None
17
        self.unlink_failed = None
18
        self.rmdir_count = None
19
        self.rmdir_failed = None
20
21
    def configure(self, args):
22
        self.unlink = print_filename if args.dry_run else remove_file
23
        self.rmdir = print_dirname if args.dry_run else remove_directory
24
        self.ignore = args.ignore
25
        self.unlink_count = 0
26
        self.unlink_failed = 0
27
        self.rmdir_count = 0
28
        self.rmdir_failed = 0
29
30
31
Runner = CleanupRunner()
32
33
34
def remove_file(fileobj):
35
    log.debug('Deleting file: %s', fileobj)
36
    try:
37
        fileobj.unlink()
38
        Runner.unlink_count += 1
39
    except OSError as err:
40
        log.debug('File not deleted. %s', err)
41
        Runner.unlink_failed += 1
42
43
44
def remove_directory(dirobj):
45
    log.debug('Removing directory: %s', dirobj)
46
    try:
47
        dirobj.rmdir()
48
        Runner.rmdir_count += 1
49
    except OSError as err:
50
        log.debug('Directory not removed. %s', err)
51
        Runner.rmdir_failed += 1
52
53
54
def print_filename(fileobj):
55
    log.debug('Would delete file: %s', fileobj)
56
    Runner.unlink_count += 1
57
58
59
def print_dirname(dirobj):
60
    log.debug('Would delete directory: %s', dirobj)
61
    Runner.rmdir_count += 1
62