diff src/gpf/inc/pco_view_templ.h @ 5:1ea54a97e831

src/gpf: import of Magnetite src/gpf3
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 15 Jul 2018 08:11:07 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/gpf/inc/pco_view_templ.h	Sun Jul 15 08:11:07 2018 +0000
@@ -0,0 +1,341 @@
+/* 
++----------------------------------------------------------------------------- 
+|  Project :  PCO2
+|  Modul   :  PCO_VIEW_TEMPLATE
++----------------------------------------------------------------------------- 
+|  Copyright 2002 Texas Instruments Berlin, AG 
+|                 All rights reserved. 
+| 
+|                 This file is confidential and a trade secret of Texas 
+|                 Instruments Berlin, AG 
+|                 The receipt of or possession of this file does not convey 
+|                 any rights to reproduce or disclose its contents or to 
+|                 manufacture, use, or sell anything it may describe, in 
+|                 whole, or in part, without the specific written consent of 
+|                 Texas Instruments Berlin, AG. 
++----------------------------------------------------------------------------- 
+|  Purpose :  This Modul contains a template of a PCO viewer class
+|             with basic functions for several PCO control messages.
+|             It can either be used just to connect to a PCO server or
+|             can be specialized and extended like in PCOView_templ.
++----------------------------------------------------------------------------- 
+*/ 
+
+#ifndef _PCO_VIEW_TEMPL_H_
+#define _PCO_VIEW_TEMPL_H_
+
+/*==== INCLUDES ===================================================*/
+#include "pco_const.h"
+
+/*==== DEFINES =====================================================*/
+
+/*==== PROTOTYPES ==================================================*/
+
+/*==== CLASSES =====================================================*/
+class PCOView_templ 
+{
+public:
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::PCOView_templ   |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : initilizes viewer process
+
+    PARAMS:   primq .. name of primitive queue
+              ctrlq .. name of control queue
+
+    RETURNS:  
+            
+  */
+  PCOView_templ(const char* primq_name="", const char* ctrlq_name="");
+  virtual ~PCOView_templ();
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::connect                    |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : tries to connect with server
+
+    PARAMS:   
+
+    RETURNS:  0 .. sucess
+              -1 .. Server not found
+              -2 .. error while contacting Server 
+            
+  */
+  int connect(void);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::subscribe       |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : tries to subscribe for live data from server
+
+    PARAMS:   mobileId .. name of mobile to receive live data from (may be empty)
+
+    RETURNS:  0 .. sucess
+              -1 .. Server not found
+              -2 .. error while contacting Server 
+            
+  */
+  int subscribe(const char* mobileId);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::send2srv        |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : tries to send a data buffer to the server
+
+    PARAMS:   buf ... pointer to buffer
+              size .. size of buffer
+              id  ... message id
+
+    RETURNS:  0 .. sucess
+              -1 .. Server not found
+              -2 .. error while contacting Server 
+            
+  */
+  int send2srv(void* buf, U16 size, U16 id);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::disconnect                 |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : tries to disconnect from server
+
+    PARAMS:   
+
+    RETURNS:  0 .. sucess
+              -1 .. Server not found
+              -2 .. error while contacting Server 
+            
+  */
+  int disconnect(void);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::unsubscribe     |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : tries to unsubscribe from livedata stream from server
+
+    PARAMS:   
+
+    RETURNS:  0 .. sucess
+              -1 .. Server not found
+              -2 .. error while contacting Server 
+            
+  */
+  int unsubscribe(void);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::on_connected    |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : reaction to PCO_CONNECTED from server
+
+    PARAMS:   buf   .. data containing server type
+              sender .. server queue name
+
+    RETURNS:   0 .. server type supported
+              -1 .. server type not supported
+            
+  */
+  virtual int on_connected(const void *buf,const char* sender);
+
+  /*
+  +---------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                   |
+  | STATE   : code                       ROUTINE : PCOView_templ::req_logfile_info  |
+  +---------------------------------------------------------------------------------+
+
+    PURPOSE : contacts server to request info about a specified logfile
+
+    PARAMS:   fname .. name of logfile (can be full path)
+
+    RETURNS:  0 .. sucess
+              -1 .. Server not found
+              -2 .. error while contacting Server 
+            
+  */
+  int req_logfile_info(const char* fname);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::get_logdata     |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : contacts server to request logged data
+
+    PARAMS:   begin, end .. index area requested 
+
+    RETURNS:  0 .. sucess
+              -1 .. Server not found
+              -2 .. error while contacting Server 
+            
+  */
+  int get_logdata(ULONG begin, ULONG end);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::open_logfile    |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : contacts server to request logged data from a specified logfile
+
+    PARAMS:   fname .. name of logfile (full path)
+              begin, end .. index area requested 
+
+    RETURNS:  0 .. sucess
+              -1 .. Server not found
+              -2 .. error while contacting Server 
+            
+  */
+  int open_logfile(const char* fname, ULONG begin=0, ULONG end=0);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::set_filter      |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : contacts server to change filter settings
+
+    PARAMS:   list ..     '\0'-separated list of names of entitities 
+                          (terminated by "\0\0")
+                          primitives/traces from entities in -list- 
+                            should not be forwarded
+
+              prim_trace  
+                      .. parameter to disable/enable general forwarding of
+                          primitives/traces:
+                         0 .. fowarding of everything (default)
+                         1 .. no primitives
+                         2 .. no traces
+              positiv_list 
+                      .. if true, only primitives/traces from entities in -list- 
+                         will be forwarded
+
+    RETURNS:  0 .. sucess
+              -1 .. Server not found
+              -2 .. error while contacting Server 
+          
+  */
+  int set_filter(const char* list, char prim_trace=0, bool positiv_list=false);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::self_send       |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : tries to send a data buffer to the control queue of this viewer
+
+    PARAMS:   buf ... pointer to buffer
+              size .. size of buffer
+              id  ... message id
+
+    RETURNS:  0  .. sucess
+              -1 .. receiver not found
+              -2 .. error while contacting receiver 
+            
+  */
+  int self_send(void* buf, U16 size, U16 id);
+
+  const char *primq_name() { return m_primq_name;}
+  const char *ctrlq_name() { return m_ctrlq_name;}
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::start_logfile   |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : contacts server to start logging data received in the given queue
+              into the given logfile
+
+    PARAMS:   logfile   .. name of the logfile 
+                           (if no path is given the current server-path is used)
+              queue     .. name of the queue the server shall receive data
+                           (it will be created by the server)
+                           (if no queue is given, m_ctrlq_name+"_LF" is used)
+
+    RETURNS:  0  .. sucess
+              -1 .. receiver not found
+              -2 .. error while contacting receiver 
+  */
+  int start_logfile(const char* logfile, const char* queue=NULL);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::stop_logfile    |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : contacts server to stop logging data received in the given queue
+
+    PARAMS:   queue     .. name of the queue the server received data
+                           (if no queue is given, m_ctrlq_name+"_LF" is used)
+
+    RETURNS:  0  .. sucess
+              -1 .. receiver not found
+              -2 .. error while contacting receiver 
+  */
+  int stop_logfile(const char* queue=NULL);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::send_raw_data   |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : sends raw data to the given queue
+
+    PARAMS:   rawdata   .. the data
+              rawsize   .. size of rawdata
+              queue     .. name of the queue the data will be sent to
+                           (if no queue is given, m_ctrlq_name+"_LF" is used)
+
+    RETURNS:  0  .. sucess
+              -1 .. receiver not found
+              -2 .. error while contacting receiver 
+  */
+  int send_raw_data(const void* rawdata, U16 rawsize, const char* queue=NULL);
+
+  /*
+  +-------------------------------------------------------------------------------+
+  | PROJECT : PCO2                       MODULE  : PCO_VIEW_TEMPL                 |
+  | STATE   : code                       ROUTINE : PCOView_templ::set_srv_name    |
+  +-------------------------------------------------------------------------------+
+
+    PURPOSE : change the name of the server queue
+
+    PARAMS:   sname ... new name of server queue
+            
+  */
+  void set_srv_name(const char* sname);
+
+  U8    srv_type() const { return m_srv_type;}
+
+protected:
+  char  m_primq_name[MAX_QNAME_LEN+1],m_ctrlq_name[MAX_QNAME_LEN+1];
+  char  m_srvq_name[MAX_QNAME_LEN+1];
+  U8    m_srv_type;
+};
+
+#endif /* _PCO_VIEW_TEMPL_H_ */