Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
snakefood / lib / python / snakefood / depends.py
Size: Mime:
"""
Routines that manipulate, read and convert lists of dependencies.
"""
# This file is part of the Snakefood open source package.
# See http://furius.ca/snakefood/ for licensing details.

import sys, logging
from operator import itemgetter



def read_depends(f):
    "Generator for the dependencies read from the given file object."
    for line in f:
        try:
            yield eval(line)
        except Exception:
            logging.warning("Invalid line: '%s'" % line)

def output_depends(depdict):
    """Given a dictionary of (from -> list of targets), generate an appropriate
    output file."""
    # Output the dependencies.
    write = sys.stdout.write
    for (from_root, from_), targets in sorted(depdict.iteritems(),
                                             key=itemgetter(0)):
        for to_root, to_ in sorted(targets):
            write(repr( ((from_root, from_), (to_root, to_)) ))
            write('\n')

def eliminate_redundant_depends(depends):
    "Remove the redundant dependencies."
    alluniq = set()
    outdeps = []
    for dep in depends:
        if dep in alluniq:
            continue
        alluniq.add(dep)
        outdeps.append(dep)
    return outdeps

def flatten_depends(depends):
    """Yield the list of dependency pairs to a single list of (root, relfn)
    pairs, in the order that they appear. The list is guaranteed to be unique
    (we remove duplicates)."""
    seen = set([(None, None)])
    for dep in depends:
        for pair in dep:
            if pair in seen:
                continue
            seen.add(pair)
            yield pair