libzypp  11.13.5
zypp::PluginScript Class Reference

Interface to pluigin scripts using a Stomp inspired communication protocol. More...

#include <PluginScript.h>

List of all members.

Classes

struct  Impl
 PluginScript implementation. More...

Public Types

typedef std::vector< std::string > Arguments
 Commandline arguments passed to a script on open.

Public Member Functions

 PluginScript ()
 Default ctor.
 PluginScript (const Pathname &script_r)
 Ctor taking script path and no arguments.
 PluginScript (const Pathname &script_r, const Arguments &args_r)
 Ctor taking script path and script arguments.
const Pathname & script () const
 Return the script path if set.
const Argumentsargs () const
 Return the script arguments if set.
bool isOpen () const
 Whether we are connected to a script.
pid_t getPid () const
 Return a connected scripts pid or NotConnected.
int lastReturn () const
 Remembers a scripts return value after close until next open.
const std::string & lastExecError () const
 Remembers a scripts execError string after close until next open.
void open ()
 Setup connection and execute script.
void open (const Pathname &script_r)
void open (const Pathname &script_r, const Arguments &args_r)
int close ()
 Close any open connection.
void send (const PluginFrame &frame_r) const
 Send a PluginFrame.
PluginFrame receive () const
 Receive a PluginFrame.
Get/set local timeout settings.
long sendTimeout () const
 Local default timeout (sec.) when sending data.
long receiveTimeout () const
 Local default timeout (sec.) when receiving data.
void sendTimeout (long newval_r)
 Set local default timeout (sec.) when sending data.
void receiveTimeout (long newval_r)
 Set local default timeout (sec.) when receiving data.
void timeout (long newval_r)
 Set local default timeout (sec.) (both: send and receive).

Static Public Member Functions

Get/set the global timeout settings.

Timeout when sending/receiving data to/from a plugin default to 30 sec.

The value (in seconds) my be changed via the environment variables ZYPP_PLUGIN_SEND_TIMEOUT, ZYPP_PLUGIN_RECEIVE_TIMEOUT or ZYPP_PLUGIN_TIMEOUT (both: send and receive).

static long defaultSendTimeout ()
 Global default timeout (sec.) when sending data.
static long defaultReceiveTimeout ()
 Global default timeout (sec.) when receiving data.
static void defaultSendTimeout (long newval_r)
 Set global default timeout (sec.) when sending data.
static void defaultReceiveTimeout (long newval_r)
 Set global default timeout (sec.) when receiving data.
static void defaultTimeout (long newval_r)
 Set global default timeout (sec.) (both: send and receive).

Static Public Attributes

static const pid_t NotConnected
 pid_t(-1) constant indicating no connection.

Private Attributes

RW_pointer< Impl_pimpl
 Pointer to implementation.

Friends

std::ostream & operator<< (std::ostream &str, const PluginScript &obj)

Related Functions

(Note that these are not member functions.)

std::ostream & operator<< (std::ostream &str, const PluginScript &obj)

Detailed Description

Interface to pluigin scripts using a Stomp inspired communication protocol.

Note:
PluginScript is copyable and assignable, but the connection is shared among multiple copies. It gets automatically closed if the last copy goes out of scope.

Timeout when sending/receiving data to/from a plugin default to 30 sec. The value (in seconds) my be changed via the environment variables ZYPP_PLUGIN_SEND_TIMEOUT, ZYPP_PLUGIN_RECEIVE_TIMEOUT or ZYPP_PLUGIN_TIMEOUT (both: send and receive).

// Setup comnnection to plugin script
args.push_back( "-v" );
scr.open( "/soem/testplugin", args );
// send frame to plugin
PluginFrame f( "COMMAND" );
f.setHeader( "key", "value" );
f.setBody( "some\ndata" );
scr.send( f );
// receive frame from plugin
PluginFrame r( scr.receive() );
// explicitly close or let PluginScript go out of scope
scr.close();
See also:
http://stomp.codehaus.org/

Definition at line 62 of file PluginScript.h.


Member Typedef Documentation

typedef std::vector<std::string> zypp::PluginScript::Arguments

Commandline arguments passed to a script on open.

Definition at line 68 of file PluginScript.h.


Constructor & Destructor Documentation

zypp::PluginScript::PluginScript ( )

Default ctor.

Definition at line 460 of file PluginScript.cc.

zypp::PluginScript::PluginScript ( const Pathname &  script_r)

Ctor taking script path and no arguments.

Definition at line 464 of file PluginScript.cc.

zypp::PluginScript::PluginScript ( const Pathname &  script_r,
const Arguments args_r 
)

Ctor taking script path and script arguments.

Definition at line 468 of file PluginScript.cc.


Member Function Documentation

long zypp::PluginScript::defaultSendTimeout ( )
static

Global default timeout (sec.) when sending data.

Definition at line 436 of file PluginScript.cc.

long zypp::PluginScript::defaultReceiveTimeout ( )
static

Global default timeout (sec.) when receiving data.

Definition at line 439 of file PluginScript.cc.

void zypp::PluginScript::defaultSendTimeout ( long  newval_r)
static

Set global default timeout (sec.) when sending data.

Definition at line 442 of file PluginScript.cc.

void zypp::PluginScript::defaultReceiveTimeout ( long  newval_r)
static

Set global default timeout (sec.) when receiving data.

Definition at line 445 of file PluginScript.cc.

static void zypp::PluginScript::defaultTimeout ( long  newval_r)
inlinestatic

Set global default timeout (sec.) (both: send and receive).

Definition at line 93 of file PluginScript.h.

const Pathname & zypp::PluginScript::script ( ) const

Return the script path if set.

Definition at line 472 of file PluginScript.cc.

const PluginScript::Arguments & zypp::PluginScript::args ( ) const

Return the script arguments if set.

Definition at line 475 of file PluginScript.cc.

bool zypp::PluginScript::isOpen ( ) const

Whether we are connected to a script.

Definition at line 478 of file PluginScript.cc.

pid_t zypp::PluginScript::getPid ( ) const

Return a connected scripts pid or NotConnected.

Definition at line 481 of file PluginScript.cc.

int zypp::PluginScript::lastReturn ( ) const

Remembers a scripts return value after close until next open.

Definition at line 484 of file PluginScript.cc.

const std::string & zypp::PluginScript::lastExecError ( ) const

Remembers a scripts execError string after close until next open.

See also:
ExternalProgram::execError.

Definition at line 487 of file PluginScript.cc.

long zypp::PluginScript::sendTimeout ( ) const

Local default timeout (sec.) when sending data.

Definition at line 448 of file PluginScript.cc.

long zypp::PluginScript::receiveTimeout ( ) const

Local default timeout (sec.) when receiving data.

Definition at line 451 of file PluginScript.cc.

void zypp::PluginScript::sendTimeout ( long  newval_r)

Set local default timeout (sec.) when sending data.

Definition at line 454 of file PluginScript.cc.

void zypp::PluginScript::receiveTimeout ( long  newval_r)

Set local default timeout (sec.) when receiving data.

Definition at line 457 of file PluginScript.cc.

void zypp::PluginScript::timeout ( long  newval_r)
inline

Set local default timeout (sec.) (both: send and receive).

Definition at line 144 of file PluginScript.h.

void zypp::PluginScript::open ( )

Setup connection and execute script.

Exceptions:
PluginScriptExceptionif already connected to a script
PluginScriptExceptionif script does not exist or is not executable
PluginScriptExceptionon error

Definition at line 490 of file PluginScript.cc.

void zypp::PluginScript::open ( const Pathname &  script_r)

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Definition at line 493 of file PluginScript.cc.

void zypp::PluginScript::open ( const Pathname &  script_r,
const Arguments args_r 
)

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Definition at line 496 of file PluginScript.cc.

int zypp::PluginScript::close ( )

Close any open connection.

Definition at line 499 of file PluginScript.cc.

void zypp::PluginScript::send ( const PluginFrame frame_r) const

Send a PluginFrame.

Exceptions:
PluginScriptNotConnected
PluginScriptSendTimeout
PluginScriptDiedUnexpectedly(does not close)
PluginScriptExceptionon error

Definition at line 502 of file PluginScript.cc.

PluginFrame zypp::PluginScript::receive ( ) const

Receive a PluginFrame.

Exceptions:
PluginScriptNotConnected
PluginScriptReceiveTimeout
PluginScriptDiedUnexpectedly(does not close)
PluginScriptExceptionon error

Definition at line 505 of file PluginScript.cc.


Friends And Related Function Documentation

std::ostream& operator<< ( std::ostream &  str,
const PluginScript obj 
)
friend

Definition at line 510 of file PluginScript.cc.

std::ostream & operator<< ( std::ostream &  str,
const PluginScript obj 
)
related

Stream output

Definition at line 510 of file PluginScript.cc.


Member Data Documentation

const pid_t zypp::PluginScript::NotConnected
static

pid_t(-1) constant indicating no connection.

Definition at line 71 of file PluginScript.h.

RW_pointer<Impl> zypp::PluginScript::_pimpl
private

Pointer to implementation.

Definition at line 185 of file PluginScript.h.


The documentation for this class was generated from the following files: