Commit Graph

23 Commits

Author SHA1 Message Date
David Wilson 9d6d342af1 Add CallError to the permitted classes list. 2016-08-16 21:26:36 +01:00
David Wilson 3de06ca559 "Ansible compatible" module loader.
Since all Ansible modules ever written are using worst practice Python,
the module loader must be rewritten to cope with their horrors.

Ansible is woeful software:

* AnsibleModule argument declarations appear within the main() function,
  so they can't be introspected prior to execution.

* No if __name__ == '__main__' guard means they can't be introspected
  without triggering execution.

* By default the main() function attempts to read from stdin, hanging
  our IO thread.

* So much unspeakable crap.

This rewrites the module loader to avoid actually running a module if it
can possibly be avoided. The downside is that the new loader must be
aware of far more details of the Python module mechanism. For example
with the new importer, namespace packages are broken at the very least.

On the plus side, now the module loader will be able to cope with
Django.
2016-08-16 21:26:11 +01:00
David Wilson ec21caa098 IOLOG re. 2016-08-16 02:55:28 +01:00
David Wilson ba3a0b6c48 Fix line numbers. 2016-08-16 02:19:15 +01:00
David Wilson fea12a6030 Many updates: graceful shutdown, docs, threading
* Start splitting docs up into internals.rst / api.rst
* Docs for lots more of econtext.core.
* Get rid of _update_stream() and has_output(), replace with individual
  functions called as state changes.
* Add Broker.on_thread() and remove Stream._lock: simply call
  on_thread() to ensure buffer management is linearized.
* Rename read_side/write_side to receive_side/transmit_side like event
  handler names.
* Clean up some more repr / debug logs.
* Move handle cleanup to Context.on_shutdown where it belongs.
* Make wake() a noop when called from broker thread.
* Replace graceful_count crap with Side.graceful attribute, add
  Broker.keep_alive() to check whether any registered readers want to
  be kept alive for graceful shutdown() or any child contexts with a
  connected stream exist.
* Make master.Broker timeout slightly longer than slave broker.
* Add generic on_thread() to allow running code on the IO thread.
2016-08-16 02:04:56 +01:00
David Wilson f88b0a11e9 Python 2.4 fixes. 2016-08-14 16:46:11 +01:00
David Wilson 1f27872eda Many docs updates. 2016-08-14 16:11:20 +01:00
David Wilson 95902d94b0 Python 2.5 fix: Logger.getChild() does not exist there. 2016-08-14 12:28:53 +01:00
David Wilson da4e457247 More docs, move call/call_with_deadline to econtext.master. 2016-08-14 12:25:44 +01:00
David Wilson 62520b1bcb Write history section. 2016-08-14 01:17:03 +01:00
David Wilson ce27058bdf Initial intro doc. 2016-08-13 22:03:58 +01:00
David Wilson cc18ab5e28 Tidy up event names and docstrings. 2016-08-13 22:03:58 +01:00
David Wilson d6d13ee506 Rationalize _fixup_package(), fix _setup_master() name. 2016-08-13 22:03:58 +01:00
David Wilson 0e58a48611 Fix method naming everywhere. 2016-08-13 22:03:58 +01:00
David Wilson 70c2032bb2 Another hackish graceful shutdown method. 2016-08-13 22:03:58 +01:00
David Wilson 9a8fc5e167 Another attempt at graceful shutdown. 2016-08-13 22:03:57 +01:00
David Wilson 4bf9d35e74 Better LocalStream bootstrap failure message. 2016-08-13 22:03:57 +01:00
David Wilson 8216edd755 Quieter logging of ImportError. 2016-08-13 22:03:57 +01:00
David Wilson d9e9d94f30 GetLocal(python_path=...) 2016-08-13 22:03:57 +01:00
David Wilson 7683ee060e Split out GetPreamble. 2016-08-13 22:03:56 +01:00
David Wilson 8fdedff8e7 Do docstring and comment removal before compression. 2016-08-13 22:03:56 +01:00
David Wilson bca3a65157 Use set_cloexec() everywhere. 2016-08-13 22:03:56 +01:00
David Wilson 274f7f91a3 Oops, forgot to check in master.py. 2016-08-13 22:03:56 +01:00