feat(hos_client_create, hos_client_destory): 多次调用destory不会导致重复释放

This commit is contained in:
彭宣正
2020-12-14 17:24:58 +08:00
parent 505d529c32
commit 10b370e486
55976 changed files with 8544395 additions and 2 deletions

View File

@@ -0,0 +1,136 @@
/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#include <aws/elasticloadbalancingv2/model/SslPolicy.h>
#include <aws/core/utils/xml/XmlSerializer.h>
#include <aws/core/utils/StringUtils.h>
#include <aws/core/utils/memory/stl/AWSStringStream.h>
#include <utility>
using namespace Aws::Utils::Xml;
using namespace Aws::Utils;
namespace Aws
{
namespace ElasticLoadBalancingv2
{
namespace Model
{
SslPolicy::SslPolicy() :
m_sslProtocolsHasBeenSet(false),
m_ciphersHasBeenSet(false),
m_nameHasBeenSet(false)
{
}
SslPolicy::SslPolicy(const XmlNode& xmlNode) :
m_sslProtocolsHasBeenSet(false),
m_ciphersHasBeenSet(false),
m_nameHasBeenSet(false)
{
*this = xmlNode;
}
SslPolicy& SslPolicy::operator =(const XmlNode& xmlNode)
{
XmlNode resultNode = xmlNode;
if(!resultNode.IsNull())
{
XmlNode sslProtocolsNode = resultNode.FirstChild("SslProtocols");
if(!sslProtocolsNode.IsNull())
{
XmlNode sslProtocolsMember = sslProtocolsNode.FirstChild("member");
while(!sslProtocolsMember.IsNull())
{
m_sslProtocols.push_back(sslProtocolsMember.GetText());
sslProtocolsMember = sslProtocolsMember.NextNode("member");
}
m_sslProtocolsHasBeenSet = true;
}
XmlNode ciphersNode = resultNode.FirstChild("Ciphers");
if(!ciphersNode.IsNull())
{
XmlNode ciphersMember = ciphersNode.FirstChild("member");
while(!ciphersMember.IsNull())
{
m_ciphers.push_back(ciphersMember);
ciphersMember = ciphersMember.NextNode("member");
}
m_ciphersHasBeenSet = true;
}
XmlNode nameNode = resultNode.FirstChild("Name");
if(!nameNode.IsNull())
{
m_name = Aws::Utils::Xml::DecodeEscapedXmlText(nameNode.GetText());
m_nameHasBeenSet = true;
}
}
return *this;
}
void SslPolicy::OutputToStream(Aws::OStream& oStream, const char* location, unsigned index, const char* locationValue) const
{
if(m_sslProtocolsHasBeenSet)
{
unsigned sslProtocolsIdx = 1;
for(auto& item : m_sslProtocols)
{
oStream << location << index << locationValue << ".SslProtocols.member." << sslProtocolsIdx++ << "=" << StringUtils::URLEncode(item.c_str()) << "&";
}
}
if(m_ciphersHasBeenSet)
{
unsigned ciphersIdx = 1;
for(auto& item : m_ciphers)
{
Aws::StringStream ciphersSs;
ciphersSs << location << index << locationValue << ".Ciphers.member." << ciphersIdx++;
item.OutputToStream(oStream, ciphersSs.str().c_str());
}
}
if(m_nameHasBeenSet)
{
oStream << location << index << locationValue << ".Name=" << StringUtils::URLEncode(m_name.c_str()) << "&";
}
}
void SslPolicy::OutputToStream(Aws::OStream& oStream, const char* location) const
{
if(m_sslProtocolsHasBeenSet)
{
unsigned sslProtocolsIdx = 1;
for(auto& item : m_sslProtocols)
{
oStream << location << ".SslProtocols.member." << sslProtocolsIdx++ << "=" << StringUtils::URLEncode(item.c_str()) << "&";
}
}
if(m_ciphersHasBeenSet)
{
unsigned ciphersIdx = 1;
for(auto& item : m_ciphers)
{
Aws::StringStream ciphersSs;
ciphersSs << location << ".Ciphers.member." << ciphersIdx++;
item.OutputToStream(oStream, ciphersSs.str().c_str());
}
}
if(m_nameHasBeenSet)
{
oStream << location << ".Name=" << StringUtils::URLEncode(m_name.c_str()) << "&";
}
}
} // namespace Model
} // namespace ElasticLoadBalancingv2
} // namespace Aws