Worker.cxx
上传用户:xfwatch
上传日期:2020-12-14
资源大小:872k
文件大小:2k
源码类别:

中间件编程

开发平台:

Java

  1. /*
  2.  * JBoss, Home of Professional Open Source
  3.  * Copyright 2008, Red Hat, Inc., and others contributors as indicated
  4.  * by the @authors tag. All rights reserved.
  5.  * See the copyright.txt in the distribution for a
  6.  * full listing of individual contributors.
  7.  * This copyrighted material is made available to anyone wishing to use,
  8.  * modify, copy, or redistribute it subject to the terms and conditions
  9.  * of the GNU Lesser General Public License, v. 2.1.
  10.  * This program is distributed in the hope that it will be useful, but WITHOUT A
  11.  * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
  12.  * PARTICULAR PURPOSE.  See the GNU Lesser General Public License for more details.
  13.  * You should have received a copy of the GNU Lesser General Public License,
  14.  * v.2.1 along with this distribution; if not, write to the Free Software
  15.  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
  16.  * MA  02110-1301, USA.
  17.  */
  18. #include "Worker.h"
  19. log4cxx::LoggerPtr Worker::logger(log4cxx::Logger::getLogger("Worker"));
  20. Worker::Worker(CORBA::ORB_ptr orb, char* orbName) {
  21. //m_orb = CORBA::ORB::_duplicate(orb);
  22. this->orb = orb;
  23. this->orbName = orbName;
  24. LOG4CXX_TRACE(logger, "created" << orbName);
  25. }
  26. int Worker::svc(void) {
  27. try {
  28. this->orb->run();
  29. LOG4CXX_TRACE(logger, "terminated");
  30. // LOG4CXX_TRACE(logger, "terminating" << orbName);
  31. } catch (CORBA::Exception& e) {
  32. LOG4CXX_ERROR(logger, (char*) "Unexpected CORBA exception: "
  33. << e._name() << " orb: " << orbName);
  34. } catch (...) {
  35. LOG4CXX_ERROR(logger, (char*) "Worker caught unknown error running orborb: " << orbName);
  36. }
  37. return 0;
  38. }