summaryrefslogtreecommitdiffstats
path: root/src/modify-carddav-object.c
diff options
context:
space:
mode:
authorOBATA Akio <obache@wizdas.com>2020-02-09 18:51:21 +0900
committerTDE Gitea <gitea@mirror.git.trinitydesktop.org>2020-04-06 15:49:00 +0000
commitb03db896434a9a2eb7f47690a38750641d97cf5f (patch)
treee58d148c1972ce0a404c952e10df97bf5706429a /src/modify-carddav-object.c
parent7bf854a0989e2a4d0848f2e10e4413fd1b21100f (diff)
downloadlibcarddav-b03db896434a9a2eb7f47690a38750641d97cf5f.tar.gz
libcarddav-b03db896434a9a2eb7f47690a38750641d97cf5f.zip
Simplify lock condition
Change to handle as LOCK is not suuported for the case response of LOCK is unimplemented. Then * LOCKSUPPORT == FALSE: LOCK is not suuported * LOCKSUPPORT == TRUE: LOCK is supported * lock == 0: no LOCK error * lock == -1: failed to LOCK Signed-off-by: OBATA Akio <obache@wizdas.com>
Diffstat (limited to 'src/modify-carddav-object.c')
-rw-r--r--src/modify-carddav-object.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/src/modify-carddav-object.c b/src/modify-carddav-object.c
index 6c97ed3..30015d6 100644
--- a/src/modify-carddav-object.c
+++ b/src/modify-carddav-object.c
@@ -217,13 +217,16 @@ gboolean carddav_modify(carddav_settings* settings, carddav_error* error) {
* hoping for the best.
*/
else if (lock_error.code == 501) {
- lock_token = g_strdup("");
+ lock_error.code = 0;
+ g_free(lock_error.str);
+ lock_error.str = NULL;
+ LOCKSUPPORT = FALSE;
}
else {
lock = -1;
}
}
- if (! LOCKSUPPORT || (LOCKSUPPORT && lock_token && lock_error.code != 423)) {
+ if (lock == 0) {
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
curl_easy_setopt(curl, CURLOPT_URL, rebuild_url(settings, url));
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, settings->file);
@@ -234,7 +237,7 @@ gboolean carddav_modify(carddav_settings* settings, carddav_error* error) {
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "PUT");
res = curl_easy_perform(curl);
- if (LOCKSUPPORT && lock_token) {
+ if (LOCKSUPPORT) {
carddav_unlock_object(
lock_token, url, settings, &lock_error);
}
@@ -415,13 +418,13 @@ gboolean carddav_modify_by_uri(carddav_settings* settings, carddav_error* error)
* hoping for the best.
*/
else if (lock_error.code == 501) {
- lock_token = g_strdup("");
+ LOCKSUPPORT = FALSE;
}
else {
lock = -1;
}
}
- if (! LOCKSUPPORT || (LOCKSUPPORT && lock_token && lock_error.code != 423)) {
+ if (lock == 0) {
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
curl_easy_setopt(curl, CURLOPT_URL, rebuild_url(settings, url));
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, settings->file);
@@ -432,7 +435,7 @@ gboolean carddav_modify_by_uri(carddav_settings* settings, carddav_error* error)
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "PUT");
res = curl_easy_perform(curl);
- if (LOCKSUPPORT && lock_token) {
+ if (LOCKSUPPORT) {
carddav_unlock_object(
lock_token, url, settings, &lock_error);
}