⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 unixendpoint.cc

📁 编译工具
💻 CC
字号:
// -*- Mode: C++; -*-//                            Package   : omniORB// unixEndpoint.cc            Created on: 6 Aug 2001//                            Author    : Sai Lai Lo (sll)////    Copyright (C) 2001 AT&T Laboratories Cambridge////    This file is part of the omniORB library////    The omniORB library is free software; you can redistribute it and/or//    modify it under the terms of the GNU Library General Public//    License as published by the Free Software Foundation; either//    version 2 of the License, or (at your option) any later version.////    This library is distributed in the hope that it will be useful,//    but WITHOUT ANY WARRANTY; without even the implied warranty of//    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU//    Library General Public License for more details.////    You should have received a copy of the GNU Library General Public//    License along with this library; if not, write to the Free//    Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA//    02111-1307, USA////// Description://	*** PROPRIETORY INTERFACE ***///*  $Log: unixEndpoint.cc,v $  Revision 1.1.2.12  2004/10/18 11:46:47  dgrisby  accept() error handling didn't work on MacOS X.  Revision 1.1.2.11  2004/10/17 22:27:24  dgrisby  Handle errors in accept() properly. Thanks Kamaldeep Singh Khanuja and  Jeremy Van Grinsven.  Revision 1.1.2.10  2003/11/12 16:04:16  dgrisby  Set sockets to close on exec.  Revision 1.1.2.9  2002/04/16 12:44:27  dpg1  Fix SSL accept bug, clean up logging.  Revision 1.1.2.8  2002/03/13 16:05:40  dpg1  Transport shutdown fixes. Reference count SocketCollections to avoid  connections using them after they are deleted. Properly close  connections when in thread pool mode.  Revision 1.1.2.7  2002/01/15 16:38:14  dpg1  On the road to autoconf. Dependencies refactored, configure.ac  written. No makefiles yet.  Revision 1.1.2.6  2001/11/28 20:33:43  dpg1  Minor Unix transport bugs.  Revision 1.1.2.5  2001/08/23 10:11:16  sll  Use AF_UNIX if AF_LOCAL is not defined.  Revision 1.1.2.4  2001/08/17 17:12:42  sll  Modularise ORB configuration parameters.  Revision 1.1.2.3  2001/08/08 15:58:17  sll  Set up the socket with the permission mode set in  omniORB::unixTransportPermission.  Revision 1.1.2.2  2001/08/07 15:42:17  sll  Make unix domain connections distinguishable on both the server and client  side.  Revision 1.1.2.1  2001/08/06 15:47:44  sll  Added support to use the unix domain socket as the local transport.*/#include <omniORB4/CORBA.h>#include <omniORB4/giopEndpoint.h>#include <orbParameters.h>#include <SocketCollection.h>#include <unix/unixConnection.h>#include <unix/unixAddress.h>#include <unix/unixEndpoint.h>#include <sys/un.h>#include <stdio.h>#include <sys/types.h>#include <sys/stat.h>#include <signal.h>#include <omniORB4/linkHacks.h>OMNI_EXPORT_LINK_FORCE_SYMBOL(unixEndpoint);#ifndef AF_LOCAL#  ifdef  AF_UNIX#    define AF_LOCAL AF_UNIX#  endif#endifOMNI_NAMESPACE_BEGIN(omni)/////////////////////////////////////////////////////////////////////////unixEndpoint::unixEndpoint(const char* filename) :  pd_socket(RC_INVALID_SOCKET),  pd_new_conn_socket(RC_INVALID_SOCKET), pd_callback_func(0),  pd_callback_cookie(0) {  pd_filename = filename;  pd_address_string = unixConnection::unToString(filename);}/////////////////////////////////////////////////////////////////////////unixEndpoint::~unixEndpoint() {  if (pd_socket != RC_INVALID_SOCKET) {    unlink(pd_filename);    CLOSESOCKET(pd_socket);    pd_socket = RC_INVALID_SOCKET;  }}/////////////////////////////////////////////////////////////////////////const char*unixEndpoint::type() const {  return "giop:unix";}/////////////////////////////////////////////////////////////////////////const char*unixEndpoint::address() const {  return pd_address_string;}/////////////////////////////////////////////////////////////////////////CORBA::BooleanunixEndpoint::Bind() {  OMNIORB_ASSERT(pd_socket == RC_INVALID_SOCKET);  if ((pd_socket = socket(AF_LOCAL,SOCK_STREAM,0)) == RC_INVALID_SOCKET) {    return 0;  }  unlink(pd_filename);  SocketSetCloseOnExec(pd_socket);  struct sockaddr_un addr;  memset((void*)&addr,0,sizeof(addr));  addr.sun_family = AF_LOCAL;  strncpy(addr.sun_path, pd_filename, sizeof(addr.sun_path) - 1);  if (::bind(pd_socket,(struct sockaddr *)&addr,	               sizeof(addr)) == RC_SOCKET_ERROR) {    CLOSESOCKET(pd_socket);    return 0;  }  if (::chmod(pd_filename,orbParameters::unixTransportPermission & 0777) < 0) {    if (omniORB::trace(1)) {      omniORB::logger log;      log << "Error: cannot change permission of " << pd_filename	  << " to " << (orbParameters::unixTransportPermission & 0777) << "\n";    }    CLOSESOCKET(pd_socket);    return 0;  }  if (listen(pd_socket,5) == RC_SOCKET_ERROR) {    CLOSESOCKET(pd_socket);    return 0;  }  pd_address_string = unixConnection::unToString(pd_filename);  return 1;}/////////////////////////////////////////////////////////////////////////voidunixEndpoint::Poke() {  unixAddress* target = new unixAddress(pd_filename);  giopActiveConnection* conn;  if ((conn = target->Connect()) == 0) {    if (omniORB::trace(1)) {      omniORB::logger log;      log << "Warning: Fail to connect to myself ("	  << (const char*) pd_address_string << ") via tcp!\n";      log << "Warning: This is ignored but this may cause the ORB shutdown to hang.\n";    }  }  else {    delete conn;  }  delete target;}/////////////////////////////////////////////////////////////////////////voidunixEndpoint::Shutdown() {  SHUTDOWNSOCKET(pd_socket);  decrRefCount();  omniORB::logs(20, "Unix endpoint shut down.");}/////////////////////////////////////////////////////////////////////////giopConnection*unixEndpoint::AcceptAndMonitor(giopConnection::notifyReadable_t func,			      void* cookie) {  OMNIORB_ASSERT(pd_socket != RC_INVALID_SOCKET);  pd_callback_func = func;  pd_callback_cookie = cookie;  setSelectable(pd_socket,1,0,0);  while (1) {    pd_new_conn_socket = RC_INVALID_SOCKET;    if (!Select()) break;    if (pd_new_conn_socket != RC_INVALID_SOCKET) {      return  new unixConnection(pd_new_conn_socket,this,pd_filename,0);    }  }  return 0;}/////////////////////////////////////////////////////////////////////////CORBA::BooleanunixEndpoint::notifyReadable(SocketHandle_t fd) {  if (fd == pd_socket) {    // New connection    SocketHandle_t sock;again:    sock = ::accept(pd_socket,0,0);    if (sock == RC_SOCKET_ERROR) {      if (ERRNO == RC_EBADF) {        omniORB::logs(20, "accept() returned EBADF, unable to continue");        return 0;      }      else if (ERRNO == RC_EINTR) {        omniORB::logs(20, "accept() returned EINTR, trying again");        goto again;      }      else if (ERRNO == RC_EAGAIN) {        omniORB::logs(20, "accept() returned EAGAIN, trying again");        goto again;      }      if (omniORB::trace(20)) {        omniORB::logger log;        log << "accept() failed with unknown error " << ERRNO << "\n";      }    }    else {      pd_new_conn_socket = sock;    }    setSelectable(pd_socket,1,0,1);    return 1;  }  else {    // Existing connection    SocketLink* conn = findSocket(fd,1);    if (conn) {      pd_callback_func(pd_callback_cookie,(unixConnection*)conn);    }    return 1;  }}OMNI_NAMESPACE_END(omni)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -