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

中间件编程

开发平台:

Java

  1. /*
  2.  * JBoss, Home of Professional Open Source
  3.  * Copyright 2010, 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 "ace/ACE.h"
  19. #include "AtmiBrokerInit.h"
  20. #include <log4cxx/propertyconfigurator.h>
  21. static bool isLogInitialised = false;
  22. static log4cxx::LoggerPtr logger;
  23. #ifdef __cplusplus
  24. extern "C" {
  25. #endif
  26. BLACKTIE_CORE_DLL void init_ace() {
  27. (void) AtmiBrokerInitSingleton::instance();
  28. }
  29. #ifdef __cplusplus
  30. }
  31. #endif
  32. AtmiBrokerInit::AtmiBrokerInit() {
  33.     if (!isLogInitialised) {
  34.         char* config = ACE_OS::getenv("LOG4CXXCONFIG");
  35.         if (config != NULL)
  36.             log4cxx::PropertyConfigurator::configure(config);
  37.         else
  38.             log4cxx::PropertyConfigurator::configure("log4cxx.properties");
  39.         isLogInitialised = true;
  40.     }
  41. logger = log4cxx::Logger::getLogger("AtmiBrokerInit");
  42. LOG4CXX_DEBUG(logger, (char*) "Constructed");
  43. ACE::init();
  44. }
  45. AtmiBrokerInit::~AtmiBrokerInit() {
  46. // NB cannot log from ACE singleton destructors since the ACE_Object_Manager calls
  47. // finalizers after log4cxx has been finalized.
  48. ACE::fini();
  49. }