summaryrefslogtreecommitdiff
path: root/doc/status-1.txt
blob: 9c1e2c5944f99e318cb163f1c5d1809dc2fa7dbb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
description of distcc status indicators, version 1
Copyright (C) 2003 by Martin Pool

purpose
-------

This file describes a mooted design for a mechanism for distcc to
indicate its status for the benefit of a separate display program.
This is an external protocol so that there can be different
implementations of status monitors to suit different purposes.  

The protocol is supposed to stay stable for some time to allow people
to write their own monitors.


interface
---------

The programming interface to this is through the functions in
mon.c/mon.h.  Monitor applications should not access the files
directly.


state
-----

The state of a compiler process is described in a few variables

  cpid     Process ID of the client

  state    String describing its progress in compilation

  file     Short source filename

  host     Host definition being used

File or host may be empty strings if they are not yet known.


states
------

The following states are defined.  The list may change in later
releases.

In 2.6 the client progresses through these states in order, although
not all states may be reached by any particular process.

   Startup       Examining command line, host definition and other
                 settings, and finding a host to use. 

   Starved       Waiting because all defined hosts are completely busy. 

   Connect       Opening a TCP or SSH connection to the host and sending 
                 the first part of the request.
               
   Preprocessor  Waiting for the preprocessor to complete.

   Send          Sending the preprocessed source.

   Compile       Waiting for a local or remote compiler to complete.

   Receive       Receiving compilation results.