def handle_bin_dir(self, dpath, file_names): if self.options.no_shebang_rewrite or self.options.ignore_shebangs: return for fn in file_names: fpath = join(dpath, fn) if fix_shebang(fpath, self.options.shebang): try: res = Interpreter.from_file(fpath) except Exception as e: log.debug('cannot parse shebang %s: %s', fpath, e) else: self.result['shebangs'].add(res)
def __init__(self, interpreter, package, dpath=None, options=None): self.interpreter = interpreter self.impl = interpreter.impl self.package = package if not dpath: self.proot = "debian/%s" % self.package else: dpath = dpath.strip('/') self.proot = join('debian', self.package, dpath) self.dpath = dpath del dpath self.options = options self.result = {'requires.txt': set(), 'egg-info': set(), 'nsp.txt': set(), 'shebangs': set(), 'public_vers': set(), 'private_dirs': {}, 'compile': False, 'ext_vers': set(), 'ext_no_version': set()} for root, dirs, file_names in os.walk(self.proot): if interpreter.should_ignore(root): del dirs[:] continue self.current_private_dir = self.current_pub_version = None version = interpreter.parse_public_dir(root) if version: self.current_dir_is_public = True if version is True: version = None else: self.current_pub_version = version else: self.current_dir_is_public = False if self.current_dir_is_public: if root.endswith('-packages'): if version is not None: self.result['public_vers'].add(version) for name in ('test', 'tests'): if name in dirs: log.debug('removing dist-packages/%s (too common name)', name) rmtree(join(root, name)) dirs.remove(name) else: self.current_private_dir = self.check_private_dir(root) if not self.current_private_dir: # i.e. not a public dir and not a private dir is_bin_dir = self.is_bin_dir(root) if is_bin_dir: self.handle_bin_dir(root, file_names) else: # not a public, private or bin directory # continue with a subdirectory continue for name in dirs: dpath = join(root, name) if self.is_unwanted_dir(dpath): rmtree(dpath) dirs.remove(name) continue if self.is_egg_dir(root): self.handle_egg_dir(root, file_names) continue # check files for fn in sorted(file_names): # sorted() to make sure .so files are handled before .so.foo fpath = join(root, fn) if self.is_unwanted_file(fpath): log.debug('removing unwanted: %s', fpath) os.remove(fpath) continue if self.is_egg_file(fpath): self.handle_egg_file(fpath) continue if not exists(fpath): # possibly removed while handling .so symlinks if islink(fpath) and '.so.' in split(fpath)[-1]: # dangling symlink to (now removed/renamed) .so file # which wasn't removed yet (see test203's quux.so.0) log.info('removing dangling symlink: %s', fpath) os.remove(fpath) continue fext = splitext(fn)[-1][1:] if fext == 'so': if not self.options.no_ext_rename: fpath = self.rename_ext(fpath) ver = self.handle_ext(fpath) ver = ver or version if ver: self.current_result.setdefault('ext_vers', set()).add(ver) else: self.current_result.setdefault('ext_no_version', set()).add(fpath) if self.current_private_dir: if exists(fpath) and fext != 'so': mode = os.stat(fpath)[ST_MODE] if mode & S_IXUSR or mode & S_IXGRP or mode & S_IXOTH: if (options.no_shebang_rewrite or fix_shebang(fpath, self.options.shebang)) and \ not self.options.ignore_shebangs: try: res = Interpreter.from_file(fpath) except Exception as e: log.debug('cannot parse shebang %s: %s', fpath, e) else: self.current_result.setdefault('shebangs', set()).add(res) if fext == 'py' and self.handle_public_module(fpath) is not False: self.current_result['compile'] = True if not dirs: # try to remove directory if it's empty (and its parent if it's empty afterwards) while root: try: os.rmdir(root) log.debug('removing empty directory: %s', root) except Exception: break root = root.rsplit('/', 1)[0] if not root.startswith(self.proot): break log.debug("package %s details = %s", package, self.result)
def __init__(self, interpreter, package, dpath=None, options=None): self.interpreter = interpreter self.impl = interpreter.impl self.package = package if not dpath: self.proot = "debian/%s" % self.package else: dpath = dpath.strip('/') self.proot = join('debian', self.package, dpath) self.dpath = dpath del dpath self.options = options self.result = { 'requires.txt': set(), 'nsp.txt': set(), 'shebangs': set(), 'public_vers': set(), 'private_dirs': {}, 'compile': False, 'ext_vers': set(), 'ext_no_version': set() } for root, dirs, file_names in os.walk(self.proot): if interpreter.should_ignore(root): del dirs[:] continue self.current_private_dir = None self.current_pub_version = version = interpreter.parse_public_version( root) if self.current_pub_version: # i.e. a public site-packages directory if root.endswith('-packages'): self.result['public_vers'].add(version) else: self.current_private_dir = self.check_private_dir(root) if not self.current_private_dir: # i.e. not a public dir and not a private dir is_bin_dir = self.is_bin_dir(root) if is_bin_dir: self.handle_bin_dir(root, file_names) else: # not a public, private or bin directory # continue with a subdirectory continue for name in dirs: dpath = join(root, name) if self.is_unwanted_dir(dpath): rmtree(dpath) dirs.remove(name) continue if self.is_egg_dir(root): self.handle_egg_dir(root, file_names) continue # check files for fn in sorted(file_names): # sorted() to make sure .so files are handled before .so.foo fpath = join(root, fn) if self.is_unwanted_file(fpath): log.debug('removing unwanted: %s', fpath) os.remove(fpath) continue if self.is_egg_file(fpath): self.handle_egg_file(fpath) continue if not exists(fpath): # possibly removed while handling .so symlinks if islink(fpath) and '.so.' in split(fpath)[-1]: # dangling symlink to (now removed/renamed) .so file # which wasn't removed yet (see test203's quux.so.0) log.info('removing dangling symlink: %s', fpath) os.remove(fpath) continue fext = splitext(fn)[-1][1:] if fext == 'so': if not self.options.no_ext_rename: fpath = self.rename_ext(fpath) ver = self.handle_ext(fpath) ver = ver or version if ver: self.current_result.setdefault('ext_vers', set()).add(ver) else: self.current_result.setdefault('ext_no_version', set()).add(fpath) if self.current_private_dir: if exists(fpath) and fext != 'so': mode = os.stat(fpath)[ST_MODE] if mode & S_IXUSR or mode & S_IXGRP or mode & S_IXOTH: if (options.no_shebang_rewrite or fix_shebang(fpath, self.options.shebang)) and \ not self.options.ignore_shebangs: try: res = Interpreter.from_file(fpath) except Exception as e: log.debug('cannot parse shebang %s: %s', fpath, e) else: self.current_result.setdefault( 'shebangs', set()).add(res) if fext == 'py' and self.handle_public_module( fpath) is not False: self.current_result['compile'] = True log.debug("package %s details = %s", package, self.result)