Source code for cslbot.commands.threads
# -*- coding: utf-8 -*-
# Copyright (C) 2013-2015 Samuel Damashek, Peter Foley, James Forcier, Srijay Kasturi, Reed Koser, Christopher Reffett, and Fox Wilson
#
# 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 2
# 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, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
import re
import threading
from ..helpers.command import Command
@Command('threads')
[docs]def cmd(send, *_):
"""Enumerate threads.
Syntax: {command}
"""
thread_names = []
for x in sorted(threading.enumerate(), key=lambda k: k.name):
res = re.match(r'Thread-(\d+$)', x.name)
if res:
tid = int(res.group(1))
# Handle the main server thread (permanently listed as _worker)
if x._target.__name__ == '_worker':
thread_names.append((tid, "%s running server thread" % x.name))
# Handle the multiprocessing pool worker threads (they don't have names beyond Thread-x)
elif x._target.__module__ == 'multiprocessing.pool':
thread_names.append((tid, "%s running multiprocessing pool worker thread" % x.name))
# Handle everything else including MainThread and deferred threads
else:
res = re.match(r'Thread-(\d+)', x.name)
tid = 0
if res:
tid = int(res.group(1))
thread_names.append((tid, x.name))
for x in sorted(thread_names, key=lambda k: k[0]):
send(x[1])