twisted.py 778 B

12345678910111213141516171819202122232425
  1. from __future__ import absolute_import
  2. from apscheduler.executors.base import BaseExecutor, run_job
  3. class TwistedExecutor(BaseExecutor):
  4. """
  5. Runs jobs in the reactor's thread pool.
  6. Plugin alias: ``twisted``
  7. """
  8. def start(self, scheduler, alias):
  9. super(TwistedExecutor, self).start(scheduler, alias)
  10. self._reactor = scheduler._reactor
  11. def _do_submit_job(self, job, run_times):
  12. def callback(success, result):
  13. if success:
  14. self._run_job_success(job.id, result)
  15. else:
  16. self._run_job_error(job.id, result.value, result.tb)
  17. self._reactor.getThreadPool().callInThreadWithCallback(
  18. callback, run_job, job, job._jobstore_alias, run_times, self._logger.name)