aboutsummaryrefslogtreecommitdiff
path: root/src/server/game/Mails/Mail.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/game/Mails/Mail.cpp')
-rw-r--r--src/server/game/Mails/Mail.cpp56
1 files changed, 24 insertions, 32 deletions
diff --git a/src/server/game/Mails/Mail.cpp b/src/server/game/Mails/Mail.cpp
index c9ad975540b..731607645ae 100644
--- a/src/server/game/Mails/Mail.cpp
+++ b/src/server/game/Mails/Mail.cpp
@@ -252,43 +252,35 @@ void MailDraft::SendMailTo(CharacterDatabaseTransaction& trans, MailReceiver con
{
pReceiver->AddNewMailDeliverTime(deliver_time);
- if (pReceiver->IsMailsLoaded())
+ Mail* m = new Mail;
+ m->messageID = mailId;
+ m->mailTemplateId = GetMailTemplateId();
+ m->subject = GetSubject();
+ m->body = GetBody();
+ m->money = GetMoney();
+ m->COD = GetCOD();
+
+ for (MailItemMap::const_iterator mailItemIter = m_items.begin(); mailItemIter != m_items.end(); ++mailItemIter)
{
- Mail* m = new Mail;
- m->messageID = mailId;
- m->mailTemplateId = GetMailTemplateId();
- m->subject = GetSubject();
- m->body = GetBody();
- m->money = GetMoney();
- m->COD = GetCOD();
-
- for (MailItemMap::const_iterator mailItemIter = m_items.begin(); mailItemIter != m_items.end(); ++mailItemIter)
- {
- Item* item = mailItemIter->second;
- m->AddItem(item->GetGUID().GetCounter(), item->GetEntry());
- }
+ Item* item = mailItemIter->second;
+ m->AddItem(item->GetGUID().GetCounter(), item->GetEntry());
+ }
- m->messageType = sender.GetMailMessageType();
- m->stationery = sender.GetStationery();
- m->sender = sender.GetSenderId();
- m->receiver = receiver.GetPlayerGUIDLow();
- m->expire_time = expire_time;
- m->deliver_time = deliver_time;
- m->checked = checked;
- m->state = MAIL_STATE_UNCHANGED;
+ m->messageType = sender.GetMailMessageType();
+ m->stationery = sender.GetStationery();
+ m->sender = sender.GetSenderId();
+ m->receiver = receiver.GetPlayerGUIDLow();
+ m->expire_time = expire_time;
+ m->deliver_time = deliver_time;
+ m->checked = checked;
+ m->state = MAIL_STATE_UNCHANGED;
- pReceiver->AddMail(m); // to insert new mail to beginning of maillist
+ pReceiver->AddMail(m); // to insert new mail to beginning of maillist
- if (!m_items.empty())
- {
- for (MailItemMap::iterator mailItemIter = m_items.begin(); mailItemIter != m_items.end(); ++mailItemIter)
- pReceiver->AddMItem(mailItemIter->second);
- }
- }
- else if (!m_items.empty())
+ if (!m_items.empty())
{
- CharacterDatabaseTransaction temp = CharacterDatabaseTransaction(nullptr);
- deleteIncludedItems(temp);
+ for (MailItemMap::iterator mailItemIter = m_items.begin(); mailItemIter != m_items.end(); ++mailItemIter)
+ pReceiver->AddMItem(mailItemIter->second);
}
}
else if (!m_items.empty())