| Trees | Index | Help |  | 
|---|
| Module indiclient :: Class bigindiclient | 
 | 
indiclient| Method Summary | |
|---|---|
|  | |
| indi_custom_element_handler | Adds a custom handler function for an indielement, the handler will be called 
each time theindielementis received. | 
| indi_custom_vector_handler | Adds a custom handler function for an indivector, the handler will be called each 
time the vector is received. | 
| mini_element_handler | Adds handler that will be called each time the element is received. | 
| NoneType | Sends a signal to the server that tells it, that this client wants to receive indiblobobjects. | 
| indielement | Returns an indielementmatching the givendevicenameandvectornameThis method will wait until it 
has been received. | 
| indivector | Returns an indivectormatching the givendevicenameandvectornameThis method will wait until it 
has been received. | 
| NoneType | Has to be called frequently by any program using this client. | 
| NoneType | must be called in order to close the indiclient instance | 
| NoneType | Resets the connection to the server | 
| NoneType | Sends an INDI vector to the INDI server. | 
| NoneType | Sets new defhandlers. | 
| NoneType | Sets a new message handler. | 
| NoneType | Sets a new timeout handler. | 
| NoneType | prints all indivectors and their elements to the screen | 
| NoneType | Looks if the requested vector has already been received and waits until it is received otherwise | 
| NoneType | Char data handler for expat parser. | 
| NoneType | Called whenever an indivector was received with an def*vectortag. | 
| NoneType | Called whenever an INDI message has been received from the server. | 
| NoneType | Called whenever an indielement has been requested but was not received for a time longer than timeoutsince the request was 
issued. | 
| NoneType | Called during the process_eventsmethod each time an INDI 
element has been received | 
| NoneType | End of XML element handler for expat parser. | 
| NoneType | Looks in self.currentVectorfor an existing indivector 
matching thenameattibute given inattrs, and updates it according toattrs. | 
| NoneType | Looks for an existing indivector matching the deviceandnameattibutes given inattrs, and updates it according toattrs | 
| NoneType | receive data from the server | 
| NoneType | A "thread" that receives data from the server | 
| NoneType | Start XML element handler for expat parser. | 
| NoneType | Called during the process_eventsmethod each time an 
indivector element has been received | 
| Instance Variable Summary | |
|---|---|
| function | blob_def_handler: Called when a newindiblobvectoris defined by the driver 
(seeset_def_handlers) | 
| StringType | currentData: A buffer to accumulate the character data to be written into the value 
attribute ofcurrentElement | 
| indivector | currentElement: The INDI element currently being processed by the XML parser | 
| indimessage | currentMessage: The INDI message currently being processed by the XML parser | 
| indivector | currentVector: The INDI vector currently being processed by the XML parser | 
| list of indivector | defvectorlist: A list of vectors that have been received withdef*Vectorsignal at least one time | 
| xml.parsers.expat | expat: an expat XML parser | 
| StringType | host: The hostname of the INDI server, this instance ofindiclientis connected to | 
| _indilistofindivector | indivectors: The list of all indivectors received so far | 
| function | message_handler: (seeset_message_handler) | 
| function | number_def_handler: Called when a newindinumbervectoris defined by the driver 
(seeset_def_handlers) | 
| IntType | port: The port address of the INDI server, this instance ofindiclientis connected to | 
| Queue.Queue | receive_event_queue: A background process (_receiver) is continuesly receiving data 
and putting them into this queue. | 
| threading.Timer | receivetimer: needed to run the _receive thread | 
| Queue.Queue | running_queue: During its destructor indiclient puts signal into this queue in order 
to stop the background process. | 
| socket.socket.socket | socket: a TCP/IP socket to communicate with the server | 
| function | text_def_handler: Called when a newinditextvectoris defined by the driver 
(seeset_def_handlers) | 
| FloatType | timeout: A timeout value (seetimeout_handler) | 
| function | timeout_handler: This function will be called whenever an indielement has been 
requested but was not received for a time longer thantimeoutsince the request was issued. | 
| BooleanType | verbose: IfTrueall XML data will be printed to the screen | 
| _indiobjectfactory() | _factory: A factory used to create and classify objects during the XML parsing 
process. | 
| Method Details | 
|---|
| __init__(self,
          host,
          port)
     | 
| add_custom_element_handler(self, handler)Adds a custom handler function for anindielement, the handler will be called 
  each time theindielementis received. Furthermore this 
  method will call the hander once. If the element has not been received 
  yet, this function will wait until the element is received before 
  calling the handler function. If theindielementdoes not exist this method 
  will not return.
 | 
| add_custom_vector_handler(self, handler)Adds a custom handler function for anindivector, the handler will be called 
  each time the vector is received. Furthermore this method will call the 
  hander once. If the vector has not been received yet, this function 
  will wait until the vector is received before calling the handler 
  function. If the vector does not exist this method will not 
  return.
 | 
| add_mini_element_handler(self, devicename, vectorname, elementname, handlermethod)Adds handler that will be called each time the element is received. Here the handler is a function that takes only one argument, namely the element that was received. This function is deprecated. It has been replaced by theadd_custom_element_handlerfunction.
 | 
| enable_blob(self)Sends a signal to the server that tells it, that this client wants to receiveindiblobobjects. If this method is not 
  called, the server will not send anyindiblob. The DCD clients calls it each 
  time anindiblobis defined.
 | 
| get_element(self, devicename, vectorname, elementname)Returns anindielementmatching the givendevicenameandvectornameThis method will wait until it 
  has been received. In case the vector doesn't exists this routine will 
  never return.
 | 
| get_vector(self, devicename, vectorname)Returns anindivectormatching the givendevicenameandvectornameThis method will wait until it 
  has been received. In case the vector doesn't exists this routine will 
  never return.
 | 
| process_events(self)Has to be called frequently by any program using this client. All custom handler methods will called by this (and only by this) method. furthermore thedef*handlerandmassage_handlermethods will be called here. See alsoadd_custom_element_handler,set_def_handlers,set_message_handler. If you just don't 
  want to use any custom handlers and you do not use gtkindiclient 
  functions, you do not need to call this method at all.
 | 
| quit(self)must be called in order to close the indiclient instance
 | 
| reset_connection(self)Resets the connection to the server
 | 
| send_vector(self, vector)Sends an INDI vector to the INDI server.
 | 
| set_def_handlers(self, blob_def_handler, number_def_handler, switch_def_handler, text_def_handler, light_def_handler)Sets newdefhandlers. These will be called whenever an 
  indivector was received with andef*Vectortag. This means 
  that the INDI driver has called anIDDef*function and 
  thus defined a new INDI vector. These handlers will only be called once 
  for eachindivector, even if more than onedef*Vectorsignals are received, for the sameindivector.
 | 
| set_message_handler(self, handler)Sets a new message handler. This handler will be called whenever an INDI message has been received from the server.
 | 
| set_timeout_handler(self, handler)Sets a new timeout handler.
 | 
| tell(self)prints all indivectors and their elements to the screen
 | 
| wait_until_vector_available(self, devicename, vectorname)Looks if the requested vector has already been received and waits until it is received otherwise
 | 
| _char_data(self, data)Char data handler for expat parser. For details (see http://www.python.org/doc/current/lib/expat-example.html)
 | 
| _default_def_handler(self, vector, indi)Called whenever an indivector was received with andef*vectortag. This means that the INDI driver has called 
  anIDDef*function and thus defined a INDI vector. It will 
  be called only once for each element, even if more thandef*vectorsignals are received. May be replaced by a 
  custom one seeset_def_handlers
 | 
| _default_message_handler(self, message, indi)Called whenever an INDI message has been received from the server.timeoutsince the request was issued. May be replaced by a 
  custom one seeset_message_handler
 | 
| _default_timeout_handler(self, devicename, vectorname, indi)Called whenever an indielement has been requested but was not received for a time longer thantimeoutsince the request 
  was issued. May be replaced by a custom handler seeset_timeout_handler
 | 
| _element_received(self, vector, element)Called during theprocess_eventsmethod each time an INDI 
  element has been received
 | 
| _end_element(self, name)End of XML element handler for expat parser. For details (see http://www.python.org/doc/current/lib/expat-example.html)
 | 
| _get_and_update_element(self, attrs, tag)Looks inself.currentVectorfor an existing indivector 
  matching thenameattibute given inattrs, and updates it according toattrs.
 | 
| _get_and_update_vector(self, attrs, tag)Looks for an existing indivector matching thedeviceandnameattibutes given inattrs, and updates it according toattrs
 | 
| _receive(self)receive data from the server
 | 
| _receiver(self)A "thread" that receives data from the server
 | 
| _start_element(self, name, attrs)Start XML element handler for expat parser. For details (see http://www.python.org/doc/current/lib/expat-example.html)
 | 
| _vector_received(self, vector)Called during theprocess_eventsmethod each time an 
  indivector element has been received
 | 
| Instance Variable Details | 
|---|
| blob_def_handlerCalled when a newindiblobvectoris defined by the driver 
(seeset_def_handlers)
 | 
| currentDataA buffer to accumulate the character data to be written into the value attribute ofcurrentElement
 | 
| currentElementThe INDI element currently being processed by the XML parser
 | 
| currentMessageThe INDI message currently being processed by the XML parser
 | 
| currentVectorThe INDI vector currently being processed by the XML parser
 | 
| defvectorlistA list of vectors that have been received withdef*Vectorsignal at least one time
 | 
| expatan expat XML parser
 | 
| hostThe hostname of the INDI server, this instance ofindiclientis connected to
 | 
| indivectorsThe list of all indivectors received so far
 | 
| message_handler(seeset_message_handler)
 | 
| number_def_handlerCalled when a newindinumbervectoris defined by the driver 
(seeset_def_handlers)
 | 
| portThe port address of the INDI server, this instance ofindiclientis connected to
 | 
| receive_event_queueA background process (_receiver) is continuesly receiving data 
and putting them into this queue. This queue will be read by theprocess_eventsmethod, that the user has to 
call in order to process any custom handlers.
 | 
| receivetimerneeded to run the _receive thread
 | 
| running_queueDuring its destructor indiclient puts signal into this queue in order to stop the background process.
 | 
| socketa TCP/IP socket to communicate with the server
 | 
| text_def_handlerCalled when a newinditextvectoris defined by the driver 
(seeset_def_handlers)
 | 
| timeoutA timeout value (seetimeout_handler)
 | 
| timeout_handlerThis function will be called whenever an indielement has been requested but was not received for a time longer thantimeoutsince the request was issued. (see alsoset_timeout_handler)
 | 
| verboseIfTrueall XML data will be printed to the screen
 | 
| _factoryA factory used to create and classify objects during the XML parsing process.
 | 
| Trees | Index | Help |  | 
|---|
| Generated by Epydoc 2.1 on Sat Sep 10 10:26:05 2005 | http://epydoc.sf.net |