def main(): options = parse_arguments() logger = StderrLogger() if options.logfile: logger = FileLogger(options.logfile) if options.fields == 'all': options.fields = sorted(Package().__dict__.keys()) else: options.fields = options.fields.split(',') # Set up filters filters = [] if options.maintainer: filters.append(MaintainerFilter(options.maintainer)) if options.category: filters.append(CategoryFilter(options.maintainer)) if options.more_repos is not None or options.less_repos is not None: filters.append(FamilyCountFilter(more=options.more_repos, less=options.less_repos)) if options.in_repository: filters.append(InRepoFilter(options.in_repository)) if options.not_in_repository: filters.append(NotInRepoFilter(options.not_in_repository)) if options.outdated_in_repository: filters.append(OutdatedInRepoFilter(options.not_in_repository)) if not options.no_shadow: filters.append(ShadowFilter()) repomgr = RepositoryManager(options.repos_dir) repoproc = RepositoryProcessor(repomgr, options.statedir) logger.Log('dumping...') for packageset in repoproc.StreamDeserializeMulti(reponames=options.reponames): FillPackagesetVersions(packageset) if not PackagesetCheckFilters(packageset, *filters): continue if options.dump == 'packages': for package in packageset: print( options.field_separator.join( ( format_package_field(field, getattr(package, field)) for field in options.fields ) ) ) if options.dump == 'summaries': print(packageset[0].effname) best_pkg_by_repo = PackagesetToBestByRepo(packageset) for reponame in repomgr.GetNames(options.reponames): if reponame in best_pkg_by_repo: print(' {}: {} ({})'.format( reponame, best_pkg_by_repo[reponame].version, VersionClass.ToString(best_pkg_by_repo[reponame].versionclass) )) return 0
def Main(): options = ParseArguments() repomgr = RepositoryManager(options.repos_dir) repoproc = RepositoryProcessor(repomgr, options.statedir, safety_checks=not options.no_safety_checks) if options.list: print('\n'.join(repomgr.GetNames(reponames=options.reponames))) return 0 transformer = PackageTransformer(repomgr, options.rules_dir) logger = StderrLogger() if options.logfile: logger = FileLogger(options.logfile) repositories_updated = [] repositories_not_updated = [] start = timer() if options.fetch or options.parse or options.reprocess: repositories_updated, repositories_not_updated = ProcessRepositories( options=options, logger=logger, repoproc=repoproc, transformer=transformer, reponames=repomgr.GetNames(reponames=options.reponames)) if options.initdb or options.database or options.postupdate: ProcessDatabase( options=options, logger=logger, repomgr=repomgr, repoproc=repoproc, repositories_updated=repositories_updated, reponames=repomgr.GetNames(reponames=options.reponames)) if (options.parse or options.reprocess) and (options.show_unmatched_rules): ShowUnmatchedRules(options=options, logger=logger, transformer=transformer, reliable=repositories_not_updated == []) logger.Log('total time taken: {:.2f} seconds'.format((timer() - start))) return 1 if repositories_not_updated else 0
def main(): options = parse_arguments() logger = StderrLogger() if options.logfile: logger = FileLogger(options.logfile) if options.fields == 'all': options.fields = sorted(Package().__dict__.keys()) else: options.fields = options.fields.split(',') repomgr = RepositoryManager(options.repos_dir) repoproc = RepositoryProcessor(repomgr, options.statedir, options.parseddir) logger.Log('dumping...') for packageset in repoproc.iter_parsed(reponames=options.reponames): FillPackagesetVersions(packageset) if not options.all and packageset_is_shadow_only(packageset): continue if options.dump == 'packages': for package in packageset: print( options.field_separator.join( (format_package_field(field, getattr(package, field)) for field in options.fields))) if options.dump == 'summaries': print(packageset[0].effname) best_pkg_by_repo = PackagesetToBestByRepo(packageset) for reponame in repomgr.GetNames(options.reponames): if reponame in best_pkg_by_repo: print(' {}: {} ({})'.format( reponame, best_pkg_by_repo[reponame].version, VersionClass.ToString( best_pkg_by_repo[reponame].versionclass))) return 0