#!/usr/bin/env python2

# THIS FILE IS PART OF THE CYLC SUITE ENGINE.
# Copyright (C) 2008-2019 NIWA & British Crown (Met Office) & Contributors.
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
"""cylc [control] jobs-kill JOB-LOG-ROOT [JOB-LOG-DIR ...]

(This command is for internal use. Users should use "cylc kill".) Read job
status files to obtain the names of the batch systems and the job IDs in the
systems. Invoke the relevant batch system commands to ask the batch systems to
terminate the jobs.

"""


from cylc.remote import remrun


def main():
    """CLI main."""
    parser = COP(__doc__, argdoc=[
        ("JOB-LOG-ROOT", "The log/job sub-directory for the suite"),
        ("[JOB-LOG-DIR ...]", "A point/name/submit_num sub-directory")])
    args = parser.parse_args()[1]
    BatchSysManager().jobs_kill(args[0], args[1:])


if __name__ == "__main__" and not remrun():
    from cylc.option_parsers import CylcOptionParser as COP
    from cylc.batch_sys_manager import BatchSysManager
    main()
