summaryrefslogtreecommitdiff
path: root/ace/ATM_Connector.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'ace/ATM_Connector.cpp')
-rw-r--r--ace/ATM_Connector.cpp78
1 files changed, 78 insertions, 0 deletions
diff --git a/ace/ATM_Connector.cpp b/ace/ATM_Connector.cpp
index 2d4f03be550..496b2ff5a27 100644
--- a/ace/ATM_Connector.cpp
+++ b/ace/ATM_Connector.cpp
@@ -26,4 +26,82 @@ ACE_ATM_Connector::ACE_ATM_Connector (void)
ACE_TRACE ("ACE_ATM_Connector::ACE_ATM_Connector");
}
+// Actively connect and produce a new ACE_ATM_Stream if things go well...
+// Connect the <new_stream> to the <remote_sap>, waiting up to
+// <timeout> amount of time if necessary.
+
+int
+ACE_ATM_Connector::connect (ACE_ATM_Stream &new_stream,
+ const ACE_ATM_Addr &remote_sap,
+ ACE_ATM_Params params,
+ ACE_ATM_QoS options,
+ ACE_Time_Value *timeout,
+ const ACE_ATM_Addr &local_sap,
+ int reuse_addr,
+ int flags,
+ int perms)
+{
+ ACE_TRACE ("ACE_ATM_Connector::connect");
+#if defined (ACE_HAS_FORE_ATM_XTI)
+ return connector_.connect(new_stream.get_stream(),
+ remote_sap,
+ timeout,
+ local_sap,
+ reuse_addr,
+ flags,
+ perms,
+ params.get_device(),
+ params.get_info(),
+ params.get_rw_flag(),
+ params.get_user_data(),
+ &options.get_qos());
+#elif defined (ACE_HAS_FORE_ATM_WS2)
+ ACE_OS::printf( "ATM_Connector(connect): set QoS parameters\n" );
+
+// return connector_.connect(new_stream.get_stream(),
+// remote_sap,
+// options.get_option_params(),
+// timeout,
+// local_sap,
+// 0,
+// 0,
+// flags,
+// reuse_addr,
+// perms,
+// params.get_protocol_family(),
+// params.get_protocol());
+
+ ACE_HANDLE s = new_stream.get_handle();
+ struct sockaddr_atm *saddr = ( struct sockaddr_atm *)remote_sap.get_addr();
+ ACE_QoS cqos = options.get_qos();
+
+ ACE_QoS_Params qos_params = ACE_QoS_Params( 0, 0, &cqos, 0, 0 );
+
+ ACE_OS::printf( "ATM_Connector(connect): connecting...\n" );
+
+ int result = ACE_OS::connect( s,
+ ( struct sockaddr *)saddr,
+ sizeof( struct sockaddr_atm ),
+ qos_params );
+
+ if ( result != 0 )
+ ACE_OS::printf( "ATM_Connector(connect): connection failed, %d\n",
+ ::WSAGetLastError());
+
+ return result;
+#else
+ ACE_UNUSED_ARG (new_stream);
+ ACE_UNUSED_ARG (remote_sap);
+ ACE_UNUSED_ARG (params);
+ ACE_UNUSED_ARG (options);
+ ACE_UNUSED_ARG (timeout);
+ ACE_UNUSED_ARG (local_sap);
+ ACE_UNUSED_ARG (reuse_addr);
+ ACE_UNUSED_ARG (flags);
+ ACE_UNUSED_ARG (perms);
+ return 0;
+#endif /* ACE_HAS_FORE_ATM_XTI/ACE_HAS_FORE_ATM_WS2 */
+}
+
#endif /* ACE_HAS_ATM */
+