summaryrefslogtreecommitdiff
path: root/ord.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'ord.cxx')
-rw-r--r--ord.cxx14
1 files changed, 11 insertions, 3 deletions
diff --git a/ord.cxx b/ord.cxx
index e5463ee..e4f4ec0 100644
--- a/ord.cxx
+++ b/ord.cxx
@@ -6,7 +6,7 @@
namespace QInterchange {
static Ord* ord;
- static char *item_name, *next_page;
+ static char *item_name, *order_page, *next_page;
static char* order_profile;
static char *fname, *lname, *address1, *address2, *city, *state, *zip,
*phone_day, *email;
@@ -89,19 +89,27 @@ namespace QInterchange {
if (this->profile != profile) this->profile = profile;
}
- void Ord::remove(const QString &name, const QString &nextPage)
+ void Ord::remove(const QString &name, const QString &orderPage,
+ const QString &nextPage)
{
item_name = (char *)malloc(name.size() + 1);
strcpy(item_name, name.toLatin1().constData());
+ if (orderPage.isEmpty())
+ order_page = nullptr;
+ else {
+ order_page = (char *)malloc(orderPage.size() + 1);
+ strcpy(order_page, orderPage.toLatin1().constData());
+ }
if (nextPage.isEmpty())
next_page = nullptr;
else {
next_page = (char *)malloc(nextPage.size() + 1);
strcpy(next_page, nextPage.toLatin1().constData());
}
- interchange_ord_remove(item_name, next_page,
+ interchange_ord_remove(item_name, order_page, next_page,
[](interchange_response *response) {
free(item_name);
+ if (order_page) free(order_page);
if (next_page) free(next_page);
ord->emitRemoval(QString{response->data});
interchange_free_response(response);