📄 options.cpp
字号:
// Options.cpp,v 4.22 2005/12/30 11:16:47 jwillemsen Exp#define ACE_BUILD_SVC_DLL#include "Event.h"#include "Options.h"#include "ace/Get_Opt.h"#include "ace/Log_Msg.h"#include "ace/OS_NS_string.h"#include "ace/OS_NS_strings.h"#include "ace/os_include/os_fcntl.h"ACE_RCSID(Gateway, Options, "Options.cpp,v 4.22 2005/12/30 11:16:47 jwillemsen Exp")// Static initialization.Options *Options::instance_ = 0;// Let's have a usage prompt.voidOptions::print_usage (void){ ACE_DEBUG ((LM_INFO, "gatewayd [-a {C|S}:acceptor-port] [-c {C|S}:connector-port]" " [-C consumer_config_file] [-P connection_config_filename]" " [-q socket_queue_size] [-t OUTPUT_MT|INPUT_MT] [-w time_out]" " [-b] [-d] [-v] [-T]\n" "" "\t-a Become an Acceptor\n" "\t-b Use blocking connection establishment\n" "\t-c Become a Connector\n" "\t-d debugging\n" "\t-q Use a different socket queue size\n" "\t-t Use a different threading strategy\n" "\t-v Verbose mode\n" "\t-w Time performance for a designated amount of time\n" "\t-C Use a different proxy config filename\n" "\t-P Use a different consumer config filename\n" "\t-T Tracing\n" ));}Options *Options::instance (void){ if (Options::instance_ == 0) ACE_NEW_RETURN (Options::instance_, Options, 0); return Options::instance_;}Options::Options (void) : locking_strategy_ (0), performance_window_ (0), blocking_semantics_ (ACE_NONBLOCK), socket_queue_size_ (0), threading_strategy_ (REACTIVE), options_ (0), supplier_acceptor_port_ (DEFAULT_GATEWAY_SUPPLIER_PORT), consumer_acceptor_port_ (DEFAULT_GATEWAY_CONSUMER_PORT), supplier_connector_port_ (DEFAULT_PEER_SUPPLIER_PORT), consumer_connector_port_ (DEFAULT_PEER_CONSUMER_PORT), max_timeout_ (MAX_TIMEOUT), max_queue_size_ (MAX_QUEUE_SIZE), connection_id_ (1){ ACE_OS::strcpy (this->connection_config_file_, ACE_TEXT("connection_config")); ACE_OS::strcpy (this->consumer_config_file_, ACE_TEXT("consumer_config"));}intOptions::enabled (int option) const{ return ACE_BIT_ENABLED (this->options_, option);}Options::~Options (void){ delete this->locking_strategy_;}ACE_Lock_Adapter<ACE_SYNCH_MUTEX> *Options::locking_strategy (void) const{ return this->locking_strategy_;}voidOptions::locking_strategy (ACE_Lock_Adapter<ACE_SYNCH_MUTEX> *ls){ this->locking_strategy_ = ls;}longOptions::performance_window (void) const{ return this->performance_window_;}CONNECTION_ID &Options::connection_id (void){ return this->connection_id_;}longOptions::max_timeout (void) const{ return this->max_timeout_;}intOptions::blocking_semantics (void) const{ return this->blocking_semantics_;}intOptions::socket_queue_size (void) const{ return this->socket_queue_size_;}u_longOptions::threading_strategy (void) const{ return this->threading_strategy_;}const ACE_TCHAR *Options::connection_config_file (void) const{ return this->connection_config_file_;}const ACE_TCHAR *Options::consumer_config_file (void) const{ return this->consumer_config_file_;}u_shortOptions::consumer_acceptor_port (void) const{ return this->consumer_acceptor_port_;}u_shortOptions::supplier_acceptor_port (void) const{ return this->supplier_acceptor_port_;}u_shortOptions::consumer_connector_port (void) const{ return this->consumer_connector_port_;}longOptions::max_queue_size (void) const{ return this->max_queue_size_;}u_shortOptions::supplier_connector_port (void) const{ return this->supplier_connector_port_;}// Parse the "command-line" arguments and set the corresponding flags.intOptions::parse_args (int argc, ACE_TCHAR *argv[]){ // Assign defaults. ACE_Get_Opt get_opt (argc, argv, ACE_TEXT("a:bC:c:dm:P:p:q:r:t:vw:"), 0); for (int c; (c = get_opt ()) != EOF; ) { switch (c) { case 'a': { // Become an Acceptor. for (ACE_TCHAR *flag = ACE_OS::strtok (get_opt.opt_arg (), ACE_TEXT("|")); flag != 0; flag = ACE_OS::strtok (0, ACE_TEXT("|"))) if (ACE_OS::strncasecmp (flag, ACE_TEXT("C"), 1) == 0) { ACE_SET_BITS (this->options_, Options::CONSUMER_ACCEPTOR); if (ACE_OS::strlen (flag) > 1) // Set the Consumer Acceptor port number. this->consumer_acceptor_port_ = ACE_OS::atoi (flag + 2); } else if (ACE_OS::strncasecmp (flag, ACE_TEXT("S"), 1) == 0) { ACE_SET_BITS (this->options_, Options::SUPPLIER_ACCEPTOR); if (ACE_OS::strlen (flag) > 1) // Set the Supplier Acceptor port number. this->supplier_acceptor_port_ = ACE_OS::atoi (flag + 2); } } break; /* NOTREACHED */ case 'b': // Use blocking connection establishment. this->blocking_semantics_ = 1; break; case 'C': // Use a different proxy config filename. ACE_OS::strncpy (this->consumer_config_file_, get_opt.opt_arg (), sizeof this->consumer_config_file_ / sizeof (ACE_TCHAR)); break; case 'c': { // Become a Connector. for (ACE_TCHAR *flag = ACE_OS::strtok (get_opt.opt_arg (), ACE_TEXT("|")); flag != 0; flag = ACE_OS::strtok (0, ACE_TEXT("|"))) if (ACE_OS::strncasecmp (flag, ACE_TEXT("C"), 1) == 0) { ACE_SET_BITS (this->options_, Options::CONSUMER_CONNECTOR); if (ACE_OS::strlen (flag) > 1) // Set the Consumer Connector port number. this->consumer_connector_port_ = ACE_OS::atoi (flag + 2); } else if (ACE_OS::strncasecmp (flag, ACE_TEXT("S"), 1) == 0) { ACE_SET_BITS (this->options_, Options::SUPPLIER_CONNECTOR); if (ACE_OS::strlen (flag) > 1) // Set the Supplier Connector port number. this->supplier_connector_port_ = ACE_OS::atoi (flag + 2); } } break; /* NOTREACHED */ case 'd': // We are debugging. ACE_SET_BITS (this->options_, Options::DEBUG); break; case 'P': // Use a different connection config filename. ACE_OS::strncpy (this->connection_config_file_, get_opt.opt_arg (), sizeof this->connection_config_file_); break; case 'q': // Use a different socket queue size. this->socket_queue_size_ = ACE_OS::atoi (get_opt.opt_arg ()); break; case 't': // Use a different threading strategy. { for (ACE_TCHAR *flag = ACE_OS::strtok (get_opt.opt_arg (), ACE_TEXT("|")); flag != 0; flag = ACE_OS::strtok (0, ACE_TEXT("|"))) if (ACE_OS::strcmp (flag, ACE_TEXT("OUTPUT_MT")) == 0) ACE_SET_BITS (this->threading_strategy_, Options::OUTPUT_MT); else if (ACE_OS::strcmp (flag, ACE_TEXT("INPUT_MT")) == 0) ACE_SET_BITS (this->threading_strategy_, Options::INPUT_MT); break; } case 'v': // Verbose mode. ACE_SET_BITS (this->options_, Options::VERBOSE); break; case 'w': // Time performance for a designated amount of time. this->performance_window_ = ACE_OS::atoi (get_opt.opt_arg ()); // Use blocking connection semantics so that we get accurate // timings (since all connections start at once). this->blocking_semantics_ = 0; break; default: this->print_usage(); // It's nice to have a usage prompt. break; } } return 0;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -