SubprocessTao
pytao.SubprocessTao
SubprocessTao(*args, env=None, **kwargs)
Bases: Tao
Subprocess helper for Tao.
This special version of the Tao
class executes a Python subprocess which
interacts with Tao through ctypes.
This can be used exactly as the normal Tao
object with the primary added
benefit that Fortran crashes will not affect the main Python process.
For full parameter information, see the Tao
class documentation.
Usage
When creating many SubprocessTao
objects, ensure to close the subprocess
when done with it. This can be done manually:
>>> tao.close_subprocess()
Or automatically by way of a context manager:
>>> with SubprocessTao(init_file="$ACC_ROOT_DIR/bmad-doc/tao_examples/cbeta_cell/tao.init", plot=True) as tao:
... tao.plot("floor")
To add a new environment variable in addition to the parent process environment:
>>> import os
>>> with SubprocessTao(init_file="...", env={**os.environ, "NEW_VAR": "NEW_VALUE"}) as tao:
... print(tao.version())
Parameters:
Name | Type | Description | Default |
---|---|---|---|
env
|
dict[str, str] or None
|
Environment variables to use for the subprocess. If None, defaults to
|
None
|
Attributes:
Name | Type | Description |
---|---|---|
subprocess_env |
dict[str, str]
|
Environment variables to use for the subprocess. It is recommended to
use a new |
Source code in pytao/subproc.py
537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 |
|
Attributes
pytao.SubprocessTao.subprocess_alive
property
subprocess_alive
Subprocess is still running.
Functions
pytao.SubprocessTao.close_subprocess
close_subprocess(*, force=False)
Close the Tao subprocess.
Source code in pytao/subproc.py
563 564 565 566 567 568 569 570 |
|
pytao.SubprocessTao.cmd
cmd(cmd, raises=True)
Runs a command, and returns the output.
Source code in pytao/subproc.py
650 651 652 653 654 |
|
pytao.SubprocessTao.cmd_integer
cmd_integer(cmd, raises=True)
Runs a command, and returns an integer array.
Source code in pytao/subproc.py
662 663 664 665 666 |
|
pytao.SubprocessTao.cmd_real
cmd_real(cmd, raises=True)
Runs a command, and returns a floating point array.
Source code in pytao/subproc.py
656 657 658 659 660 |
|
pytao.SubprocessTao.get_active_beam_track_element
get_active_beam_track_element()
Get the active element index being tracked.
Source code in pytao/subproc.py
668 669 670 671 |
|
pytao.SubprocessTao.subprocess_call
subprocess_call(func, **kwargs)
Run a custom function in the subprocess.
The function must be readily importable by Python and not a dynamically
created function or lambda
. The first argument passed will be the
tao
object, and the remainder of the arguments are user-specified by
keyword only.
Source code in pytao/subproc.py
623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 |
|
pytao.SubprocessTao.timeout
timeout(when)
Context manager to set a timeout for a block of SubprocessTao calls.
Note that there is no possibility for a graceful timeout. In the event of a timeout, the subprocess will be terminated.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
when
|
float
|
The timeout duration in seconds. |
required |
Yields:
Type | Description |
---|---|
None
|
Yields control back to the calling context. |
Raises:
Type | Description |
---|---|
TimeoutError
|
If the block of code does not execute within |
Source code in pytao/subproc.py
572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 |
|