Skip to content

Commit

Permalink
Merge pull request #1449 from clinton-hall/release-11.7
Browse files Browse the repository at this point in the history
Release 11.07
  • Loading branch information
labrys authored Dec 25, 2018
2 parents 697ae37 + 38a113e commit 5907321
Show file tree
Hide file tree
Showing 5 changed files with 107 additions and 1 deletion.
5 changes: 5 additions & 0 deletions TorrentToMedia.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,10 @@
#!/usr/bin/env python2
# coding=utf-8

import cleanup
cleanup.clean('core', 'libs')


import datetime
import os
import sys
Expand Down
9 changes: 9 additions & 0 deletions changelog.txt
Original file line number Diff line number Diff line change
@@ -1,5 +1,14 @@
Change_LOG / History

V11.7 12/25/2018

Merry Christmas and Happy Holidays!

Add cleanup script to clean up bytecode
Add automatic cleanup on update

NOTE: Cleanup will force-run every time during a transitional period to minimize issues with upcoming refactoring

V11.06 11/03/2018

updates to incorporate importMode for NzbDrone/Sonarr and Radarr.
Expand Down
86 changes: 86 additions & 0 deletions cleanup.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
from __future__ import print_function

import subprocess
import sys


def git_clean(remove_directories=False, force=False, dry_run=False, interactive=False, quiet=False, exclude=None,
ignore_rules=False, clean_ignored=False, paths=None):
"""Execute git clean commands."""
command = ['git', 'clean']
if remove_directories:
command.append('-d')
if force:
command.append('--force')
if interactive:
command.append('--interactive')
if quiet:
command.append('--quiet')
if dry_run:
command.append('--dry-run')
if exclude:
try:
exclude = exclude.split(' ')
except AttributeError:
pass
for exclusion in exclude:
command.append('--exclude={pattern}'.format(pattern=exclusion))
if ignore_rules:
command.append('-x')
if clean_ignored:
command.append('-X')
if paths:
try:
paths = paths.split(' ')
except AttributeError:
pass
command.extend(paths)
return subprocess.check_output(command)


def clean_bytecode():
"""Clean bytecode files."""
try:
result = git_clean(
remove_directories=True,
force=True,
exclude=[
'*.*', # exclude everything
'!*.py[co]', # except bytecode
'!**/__pycache__/', # and __pycache__ folders
],
)
except subprocess.CalledProcessError as error:
sys.exit(error.returncode)
else:
return result


def clean_folders(*paths):
"""Clean obsolete folders."""
try:
result = git_clean(
remove_directories=True,
force=True,
ignore_rules=True,
paths=paths,
)
except subprocess.CalledProcessError as error:
sys.exit(error.returncode)
else:
return result


def clean(*paths):
"""Clean up bytecode and obsolete folders."""
print('-- Cleaning bytecode --')
result = clean_bytecode()
print(result or 'No bytecode to clean\n')
if paths:
print('-- Cleaning folders: {} --'.format(paths))
result = clean_folders(*paths)
print(result or 'No folders to clean\n')


if __name__ == '__main__':
clean('libs', 'core')
5 changes: 4 additions & 1 deletion core/versionCheck.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
import traceback
import gh_api as github

import cleanup
import core
from core import logger

Expand Down Expand Up @@ -79,7 +80,9 @@ def check_for_new_version(self, force=False):

def update(self):
if self.updater.need_update():
return self.updater.update()
result = self.updater.update()
cleanup.clean('core', 'libs')
return result


class UpdateManager(object):
Expand Down
3 changes: 3 additions & 0 deletions nzbToMedia.py
Original file line number Diff line number Diff line change
Expand Up @@ -623,6 +623,9 @@

from __future__ import print_function

import cleanup
cleanup.clean('core', 'libs')

import os
import sys
import datetime
Expand Down

0 comments on commit 5907321

Please sign in to comment.