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

pyclean.runner   A

Complexity

Total Complexity 10

Size/Duplication

Total Lines 62
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
wmc 10
eloc 43
dl 0
loc 62
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A CleanupRunner.configure() 0 8 3
A CleanupRunner.__init__() 0 8 1

4 Functions

Rating   Name   Duplication   Size   Complexity  
A remove_file() 0 8 2
A print_dirname() 0 3 1
A print_filename() 0 3 1
A remove_directory() 0 8 2
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