<p> Attention is currently required from: Joshua Colp, Kevin Harwell. </p>
<p><a href="https://gerrit.asterisk.org/c/asterisk/+/18012">View Change</a></p><p>2 comments:</p><ul style="list-style: none; padding: 0;"><li style="margin: 0; padding: 0;"><p><a href="null">File funcs/func_json.c:</a></p><ul style="list-style: none; padding: 0;"><li style="margin: 0; padding: 0 0 0 16px;"><p style="margin-bottom: 4px;"><a href="https://gerrit.asterisk.org/c/asterisk/+/18012/comment/cd91341b_05fab16a">Patch Set #4, Line 90:</a> </p><p><blockquote style="border-left: 1px solid #aaa; margin: 10px 0; padding: 0 10px;"><pre style="font-family: monospace,monospace; white-space: pre-wrap;">static int parse_node(char **key, char *currentkey, char *nestchar, int count, struct ast_json *json, char *buf, size_t len)<br>{<br> const char *result = NULL;<br> char *previouskey;<br> struct ast_json *jsonval = json;<br><br> snprintf(buf, len, "%s", ""); /* clear the buffer from previous round if necessary */<br> if (!json) { /* no error or warning should be thrown */<br> ast_debug(1, "Could not find key '%s' in parsed JSON\n", currentkey);<br> return -1;<br> }<br><br> switch(ast_json_typeof(jsonval)) {<br> unsigned long int size;<br> int r;<br> char *result2;<br><br> case AST_JSON_STRING:<br> ast_debug(1, "Got JSON string\n");<br> result = ast_json_string_get(jsonval);<br> snprintf(buf, len, "%s", result);<br> break;<br> case AST_JSON_INTEGER:<br> ast_debug(1, "Got JSON integer\n");<br> r = ast_json_integer_get(jsonval);<br> snprintf(buf, len, "%d", r); /* the snprintf below is mutually exclusive with this one */<br> break;<br> case AST_JSON_ARRAY:<br> ast_debug(1, "Got JSON array\n");<br> previouskey = currentkey;<br> currentkey = strsep(key, nestchar); /* retrieve the desired index */<br> size = ast_json_array_size(jsonval);<br> ast_debug(1, "Parsed JSON array of size %lu, key: %s\n", size, currentkey);<br> if (!currentkey) { /* this is the end, so just dump the array */<br> if (count) {<br> ast_debug(1, "No key on which to index in the array, so returning count: %lu\n", size);<br> snprintf(buf, len, "%lu", size);<br> return 0;<br> } else {<br> char *jsonarray;<br> ast_debug(1, "No key on which to index in the array, so dumping '%s' array\n", previouskey);<br> jsonarray = ast_json_dump_string(jsonval);<br> ast_copy_string(buf, jsonarray, len);<br> ast_json_free(jsonarray);<br> }<br> } else if (ast_str_to_int(currentkey, &r) || r < 0) {<br> ast_debug(1, "Requested index '%s' is not numeric or is invalid\n", currentkey);<br> } else if (r >= size) {<br> ast_debug(1, "Requested index '%d' does not exist in parsed array\n", r);<br> } else {<br> struct ast_json *json2 = ast_json_array_get(jsonval, r);<br> if (!json2) {<br> ast_debug(1, "Array index %d contains empty item\n", r);<br> return -1;<br> }<br> previouskey = currentkey;<br> currentkey = strsep(key, nestchar); /* get the next subkey */<br> ast_debug(1, "Recursing on index %d in array (key was '%s' and is now '%s')\n", r, previouskey, currentkey);<br> /* json2 is a borrowed ref. That's fine, since json won't get freed until recursing is over */<br> /* If there are keys remaining, then parse the next object we can get. Otherwise, just dump the child */<br> if (parse_node(key, currentkey, nestchar, count, currentkey ? ast_json_object_get(json2, currentkey) : json2, buf, len)) { /* recurse on this node */<br> return -1;<br> }<br> }<br> break;<br> default:<br> ast_debug(1, "Got generic JSON object\n");<br> result2 = ast_json_dump_string(jsonval);<br> snprintf(buf, len, "%s", result2);<br> ast_json_free(result2);<br> }<br> return 0;<br>}<br></pre></blockquote></p><p><blockquote style="border-left: 1px solid #aaa; margin: 10px 0; padding: 0 10px;">So I have been mucking around with this and it seems there is a difference between the previous way […]</blockquote></p><p style="white-space: pre-wrap; word-wrap: break-word;">Ack</p></li><li style="margin: 0; padding: 0 0 0 16px;"><p style="margin-bottom: 4px;"><a href="https://gerrit.asterisk.org/c/asterisk/+/18012/comment/f449731b_cc47946b">Patch Set #4, Line 235:</a> <code style="font-family:monospace,monospace"> json = ast_json_load_str(str, NULL);</code></p><p><blockquote style="border-left: 1px solid #aaa; margin: 10px 0; padding: 0 10px;">There is no reason you should have to load the json multiple times. […]</blockquote></p><p style="white-space: pre-wrap; word-wrap: break-word;">Done</p></li></ul></li></ul><p>To view, visit <a href="https://gerrit.asterisk.org/c/asterisk/+/18012">change 18012</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.asterisk.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.asterisk.org/c/asterisk/+/18012"/><meta itemprop="name" content="View Change"/></div></div>
<div style="display:none"> Gerrit-Project: asterisk </div>
<div style="display:none"> Gerrit-Branch: master </div>
<div style="display:none"> Gerrit-Change-Id: I603940b216a3911b498fc6583b18934011ef5d5b </div>
<div style="display:none"> Gerrit-Change-Number: 18012 </div>
<div style="display:none"> Gerrit-PatchSet: 9 </div>
<div style="display:none"> Gerrit-Owner: N A <asterisk@phreaknet.org> </div>
<div style="display:none"> Gerrit-Reviewer: Friendly Automation </div>
<div style="display:none"> Gerrit-Reviewer: Kevin Harwell <default.enum@gmail.com> </div>
<div style="display:none"> Gerrit-CC: Joshua Colp <jcolp@sangoma.com> </div>
<div style="display:none"> Gerrit-Attention: Joshua Colp <jcolp@sangoma.com> </div>
<div style="display:none"> Gerrit-Attention: Kevin Harwell <default.enum@gmail.com> </div>
<div style="display:none"> Gerrit-Comment-Date: Wed, 23 Nov 2022 10:40:47 +0000 </div>
<div style="display:none"> Gerrit-HasComments: Yes </div>
<div style="display:none"> Gerrit-Has-Labels: No </div>
<div style="display:none"> Comment-In-Reply-To: N A <asterisk@phreaknet.org> </div>
<div style="display:none"> Comment-In-Reply-To: Joshua Colp <jcolp@sangoma.com> </div>
<div style="display:none"> Comment-In-Reply-To: Kevin Harwell <default.enum@gmail.com> </div>
<div style="display:none"> Gerrit-MessageType: comment </div>