Skip to content
Snippets Groups Projects
Commit 5568abbb authored by Ralf Haferkamp's avatar Ralf Haferkamp
Browse files

- Plugged memory leak default constructor

- Fixed copy-constructor
parent 50a26bec
No related branches found
No related tags found
No related merge requests found
......@@ -22,8 +22,11 @@ LDAPEntry::LDAPEntry(const LDAPEntry& entry){
LDAPEntry::LDAPEntry(const string& dn, const LDAPAttributeList *attrs){
DEBUG(LDAP_DEBUG_CONSTRUCT,"LDAPEntry::LDAPEntry()" << endl);
DEBUG(LDAP_DEBUG_CONSTRUCT | LDAP_DEBUG_PARAMETER,
" dn:" << dn << endl << " attrs:" << *attrs << endl);
m_attrs=new LDAPAttributeList(*attrs);
" dn:" << dn << endl);
if ( attrs )
m_attrs=new LDAPAttributeList(*attrs);
else
m_attrs=new LDAPAttributeList();
m_dn=dn;
}
......@@ -40,6 +43,13 @@ LDAPEntry::~LDAPEntry(){
delete m_attrs;
}
LDAPEntry& LDAPEntry::operator=(const LDAPEntry& from){
m_dn = from.m_dn;
delete m_attrs;
m_attrs = new LDAPAttributeList( *(from.m_attrs));
return *this;
}
void LDAPEntry::setDN(const string& dn){
DEBUG(LDAP_DEBUG_TRACE,"LDAPEntry::setDN()" << endl);
DEBUG(LDAP_DEBUG_TRACE | LDAP_DEBUG_PARAMETER,
......
......@@ -30,7 +30,7 @@ class LDAPEntry{
* @param attrs The attributes for the new entry.
*/
LDAPEntry(const std::string& dn=std::string(),
const LDAPAttributeList *attrs=new LDAPAttributeList());
const LDAPAttributeList *attrs=0);
/**
* Used internally only.
......@@ -44,7 +44,12 @@ class LDAPEntry{
* Destructor
*/
~LDAPEntry();
/**
* Assingment operator
*/
LDAPEntry& operator=(const LDAPEntry& from);
/**
* Sets the DN-attribute.
* @param dn: The new DN for the entry.
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment