X-Git-Url: http://www.project-moonshot.org/gitweb/?a=blobdiff_plain;f=saml%2Finternal.h;h=81833212e6dea9adfbe9f309d68799584d8d7c1c;hb=c6e08d702143f0337cd592d1599bd78d50c38873;hp=675a5e77a02b999be822bc6ea96f29b08b5345c8;hpb=099f6c2a2b356d31f88f727e0e6f9abae76e8be2;p=shibboleth%2Fcpp-opensaml.git diff --git a/saml/internal.h b/saml/internal.h index 675a5e7..8183321 100644 --- a/saml/internal.h +++ b/saml/internal.h @@ -1,17 +1,21 @@ -/* - * Copyright 2001-2005 Internet2 - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at +/** + * Licensed to the University Corporation for Advanced Internet + * Development, Inc. (UCAID) under one or more contributor license + * agreements. See the NOTICE file distributed with this work for + * additional information regarding copyright ownership. + * + * UCAID licenses this file to you under the Apache License, + * Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. You may obtain a copy of the + * License at * - * http://www.apache.org/licenses/LICENSE-2.0 + * http://www.apache.org/licenses/LICENSE-2.0 * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, + * either express or implied. See the License for the specific + * language governing permissions and limitations under the License. */ /* @@ -24,6 +28,7 @@ #ifdef WIN32 # define _CRT_SECURE_NO_DEPRECATE 1 # define _CRT_NONSTDC_NO_DEPRECATE 1 +# define _SCL_SECURE_NO_WARNINGS 1 #endif // Export public APIs @@ -41,6 +46,8 @@ #include +using namespace xercesc; + // C99 defines LLONG_MIN, LLONG_MAX and ULLONG_MAX, but this part of // C99 is not yet included into the C++ standard. // GCC defines LONG_LONG_MIN, LONG_LONG_MAX and ULONG_LONG_MAX. @@ -73,30 +80,38 @@ #if SIZEOF_TIME_T == 8 # define SAMLTIME_MAX LLONG_MAX #elif SIZEOF_TIME_T == 4 -# define SAMLTIME_MAX LONG_MAX +# define SAMLTIME_MAX INT_MAX #endif #define SAML_LOGCAT "OpenSAML" +namespace xmltooling { + class XMLTOOL_API Mutex; +}; + namespace opensaml { /// @cond OFF - class SAMLInternalConfig : public SAMLConfig + class SAML_DLLLOCAL SAMLInternalConfig : public SAMLConfig { public: - SAMLInternalConfig() {} + SAMLInternalConfig(); + ~SAMLInternalConfig(); static SAMLInternalConfig& getInternalConfig(); // global per-process setup and shutdown of runtime - bool init(); - void term(); + bool init(bool initXMLTooling=true); + void term(bool termXMLTooling=true); void generateRandomBytes(void* buf, unsigned int len); void generateRandomBytes(std::string& buf, unsigned int len); XMLCh* generateIdentifier(); std::string hashSHA1(const char* data, bool toHex=false); + private: + int m_initCount; + std::auto_ptr m_lock; }; /// @endcond