#!/usr/bin/env python
"""
    jldfilter - filters stdin through Python module, out to stdout


    See https://www.systemical.com/doc/opensource/jlddk  for more details

    http://docs.python.org/dev/library/argparse.html#nargs
    nargs="n" : n arguments grouped in a list
    nargs="?" : 1 argument, optional
    nargs="*" : list of arguments
    nargs="+" : a list of at least 1 element

    @author: Jean-Lou Dupont
"""
import os, sys, argparse
op=os.path

try:
    import jlddk
except:
    ### must be in dev mode then    
    this_dir=op.dirname(__file__)
    lib_path=op.abspath(op.join(this_dir, ".."))
    sys.path.insert(0, lib_path)
    import jlddk

########################################################################

DESC="Filters stdin stream through Python function ==> stdout"
DEFAULTS={
          
          }

def main():
    try:
        import jlddk.do_setup
        import logging
        import jlddk.do_checks
        from jlddk.tools_sys import dnorm, info_dump
        
        parser=argparse.ArgumentParser(description=DESC, fromfile_prefix_chars='@')
        parser.add_argument('-m',   dest="module",        type=str,  help="Python module", required=True)
        parser.add_argument('-f',   dest="function",      type=str,  help="Python function inside module", required=True)
        parser.add_argument('-a',   dest="function_args", nargs='+', help="Arguments to function inside module", default=[])
        
        parser.add_argument('-lc',  dest="logconfig", type=str,  help="Logging configuration file", choices=["debug", "info", "warning", "error"])
        parser.add_argument('-ll',  dest="loglevel",  type=str,  help="Logging Level", choices=["debug", "info", "warning", "error"], default="info")        
        args=parser.parse_args()
        
        info_dump(vars(args), 20)
        
        from jlddk.script_filter import run
        run(**dnorm(vars(args)))

    except KeyboardInterrupt:
        logging.info("..Exiting")
        sys.exit(0)##no probs
        
    except Exception,e:
        logging.error(str(e))
        sys.exit(1)
        
sys.exit(main())
