38
SAVEPOINT **sv, *newsv;
39
for (sv= &session->transaction.savepoints; *sv; sv= &(*sv)->prev)
45
* Look through the savepoints. If we find one with
46
* the same name, delete it.
48
TransactionServices &transaction_services= TransactionServices::singleton();
49
deque<NamedSavepoint> &savepoints= session->transaction.savepoints;
50
deque<NamedSavepoint>::iterator iter;
52
for (iter= savepoints.begin();
53
iter != savepoints.end();
56
NamedSavepoint &sv= *iter;
57
const string &sv_name= sv.getName();
41
58
if (my_strnncoll(system_charset_info,
42
59
(unsigned char *) session->lex->ident.str,
43
60
session->lex->ident.length,
44
(unsigned char *) (*sv)->name,
48
TransactionServices &transaction_services= TransactionServices::singleton();
49
if (*sv) /* old savepoint of the same name exists */
52
transaction_services.ha_release_savepoint(session, *sv); // it cannot fail
55
else if ((newsv= (SAVEPOINT *) alloc_root(&session->transaction.mem_root,
56
savepoint_alloc_size)) == 0)
58
my_error(ER_OUT_OF_RESOURCES, MYF(0));
61
newsv->name= strmake_root(&session->transaction.mem_root,
62
session->lex->ident.str,
63
session->lex->ident.length);
64
newsv->length= session->lex->ident.length;
66
if we'll get an error here, don't add new savepoint to the list.
67
we'll lose a little bit of memory in transaction mem_root, but it'll
68
be free'd when transaction ends anyway
61
(unsigned char *) sv_name.c_str(),
65
if (iter != savepoints.end())
67
NamedSavepoint &sv= *iter;
68
(void) transaction_services.ha_release_savepoint(session, sv);
69
savepoints.erase(iter);
72
NamedSavepoint newsv(session->lex->ident.str, session->lex->ident.length);
70
74
if (transaction_services.ha_savepoint(session, newsv))
76
newsv->prev= session->transaction.savepoints;
77
session->transaction.savepoints= newsv;
80
savepoints.push_front(newsv);