From a603e4d26384d24a96da51008cf33f2e9e8ff6f2 Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Tue, 27 Aug 2024 08:09:28 +0200 Subject: [PATCH] trurl: optimize the path append loop Extract the path once, do all the appends then set the final version once in the end. Instead of doing it every loop. --- tests.json | 16 ++++++++++++++++ trurl.c | 24 ++++++++++++++---------- 2 files changed, 30 insertions(+), 10 deletions(-) diff --git a/tests.json b/tests.json index 59ce2385..b0a97576 100644 --- a/tests.json +++ b/tests.json @@ -2557,6 +2557,22 @@ "returncode": 0 } }, + { + "input": { + "arguments": [ + "example.com", + "--append", + "path=add", + "--append", + "path=two" + ] + }, + "expected": { + "stdout": "http://example.com/add/two\n", + "stderr": "", + "returncode": 0 + } + }, { "input": { "arguments": [ diff --git a/trurl.c b/trurl.c index fca5270c..a69b89fa 100644 --- a/trurl.c +++ b/trurl.c @@ -1685,15 +1685,17 @@ static void singleurl(struct option *o, } if(first_lap) { + /* extract the current path */ + char *opath; + bool path_is_modified = false; + if(curl_url_get(uh, CURLUPART_PATH, &opath, 0)) + errorf(o, ERROR_ITER, "out of memory"); + /* append path segments */ for(p = o->append_path; p; p = p->next) { char *apath = p->data; - char *opath; char *npath; size_t olen; - /* extract the current path */ - if(curl_url_get(uh, CURLUPART_PATH, &opath, 0)) - errorf(o, ERROR_ITER, "out of memory"); /* does the existing path end with a slash, then don't add one in between */ @@ -1703,14 +1705,16 @@ static void singleurl(struct option *o, npath = curl_maprintf("%s%s%s", opath, opath[olen-1] == '/' ? "" : "/", apath); - if(npath) { - /* set the new path */ - if(curl_url_set(uh, CURLUPART_PATH, npath, 0)) - errorf(o, ERROR_ITER, "out of memory"); - } - curl_free(npath); curl_free(opath); + opath = npath; + path_is_modified = true; + } + if(path_is_modified) { + /* set the new path */ + if(curl_url_set(uh, CURLUPART_PATH, opath, 0)) + errorf(o, ERROR_ITER, "out of memory"); } + curl_free(opath); } query_is_modified |= extractqpairs(uh, o);