blob: d5e2be66e0dac0f3c4577f3364eb00f2dabefa18 [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF 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
*
* 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.
*/
/*
* XSEC
*
* XSECAutoPtr := internal classes for RAII handling of transcoded data
*
* Author(s): Scott Cantor
*
* $Id:$
*
*/
#ifndef XSECAUTOPTR_INCLUDE
#define XSECAUTOPTR_INCLUDE
#include <xsec/framework/XSECDefs.hpp>
#include <xercesc/util/XMLString.hpp>
XSEC_USING_XERCES(XMLString);
/**
* \addtogroup internal
* @{
*/
/**
* A minimal auto_ptr-like class that can copy or transcode a buffer into
* the local code page and free the result automatically.
*
* Needed because a standard auto_ptr would use delete on the resulting
* pointer.
*/
class XSECAutoPtrChar
{
XSECAutoPtrChar(const XSECAutoPtrChar&);
XSECAutoPtrChar& operator=(const XSECAutoPtrChar&);
public:
XSECAutoPtrChar() : m_buf(NULL) {
}
XSECAutoPtrChar(const XMLCh* src) : m_buf(xercesc::XMLString::transcode(src)) {
}
XSECAutoPtrChar(const char* src) : m_buf(xercesc::XMLString::replicate(src)) {
}
~XSECAutoPtrChar() {
XSEC_RELEASE_XMLCH(m_buf);
}
const char* get() const {
return m_buf;
}
char* release() {
char* temp=m_buf; m_buf=NULL; return temp;
}
private:
char* m_buf;
};
/**
* A minimal auto_ptr-like class that can copy or transcode a buffer into
* 16-bit Unicode and free the result automatically.
*
* Needed because a standard auto_ptr would use delete on the resulting
* pointer.
*/
class XSECAutoPtrXMLCh
{
XSECAutoPtrXMLCh(const XSECAutoPtrXMLCh&);
XSECAutoPtrXMLCh& operator=(const XSECAutoPtrXMLCh&);
public:
XSECAutoPtrXMLCh() : m_buf(NULL) {
}
XSECAutoPtrXMLCh(const char* src) : m_buf(xercesc::XMLString::transcode(src)) {
}
XSECAutoPtrXMLCh(const XMLCh* src) : m_buf(xercesc::XMLString::replicate(src)) {
}
~XSECAutoPtrXMLCh() {
XSEC_RELEASE_XMLCH(m_buf);
}
const XMLCh* get() const {
return m_buf;
}
XMLCh* release() {
XMLCh* temp=m_buf; m_buf=NULL; return temp;
}
private:
XMLCh* m_buf;
};
/** @} */
#endif /* XSECAUTOPTR_INCLUDE */