You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

json__patch_8h.html 7.1 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=11"/>
  6. <meta name="generator" content="Doxygen 1.9.4"/>
  7. <meta name="viewport" content="width=device-width, initial-scale=1"/>
  8. <title>json-c: json_patch.h File Reference</title>
  9. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  10. <script type="text/javascript" src="jquery.js"></script>
  11. <script type="text/javascript" src="dynsections.js"></script>
  12. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  13. </head>
  14. <body>
  15. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  16. <div id="titlearea">
  17. <table cellspacing="0" cellpadding="0">
  18. <tbody>
  19. <tr id="projectrow">
  20. <td id="projectalign">
  21. <div id="projectname">json-c<span id="projectnumber">&#160;0.18</span>
  22. </div>
  23. </td>
  24. </tr>
  25. </tbody>
  26. </table>
  27. </div>
  28. <!-- end header part -->
  29. <!-- Generated by Doxygen 1.9.4 -->
  30. <script type="text/javascript" src="menudata.js"></script>
  31. <script type="text/javascript" src="menu.js"></script>
  32. <script type="text/javascript">
  33. /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
  34. $(function() {
  35. initMenu('',false,false,'search.php','Search');
  36. });
  37. /* @license-end */
  38. </script>
  39. <div id="main-nav"></div>
  40. </div><!-- top -->
  41. <div class="header">
  42. <div class="summary">
  43. <a href="#nested-classes">Data Structures</a> &#124;
  44. <a href="#func-members">Functions</a> </div>
  45. <div class="headertitle"><div class="title">json_patch.h File Reference</div></div>
  46. </div><!--header-->
  47. <div class="contents">
  48. <p>JSON Patch (RFC 6902) implementation for manipulating JSON objects.
  49. <a href="#details">More...</a></p>
  50. <table class="memberdecls">
  51. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a>
  52. Data Structures</h2></td></tr>
  53. <tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structjson__patch__error.html">json_patch_error</a></td></tr>
  54. <tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
  55. </table><table class="memberdecls">
  56. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a>
  57. Functions</h2></td></tr>
  58. <tr class="memitem:a134aaed1e732d029d34ce2d605f9ac8d"><td class="memItemLeft" align="right" valign="top"><a class="el" href="printbuf_8h.html#a2a31d5c00f3a4712f2d5d62aee66344e">JSON_EXPORT</a> int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="json__patch_8h.html#a134aaed1e732d029d34ce2d605f9ac8d">json_patch_apply</a> (struct <a class="el" href="json__types_8h.html#af27907ced0f5a43409ad96430fe0f914">json_object</a> *copy_from, struct <a class="el" href="json__types_8h.html#af27907ced0f5a43409ad96430fe0f914">json_object</a> *patch, struct <a class="el" href="json__types_8h.html#af27907ced0f5a43409ad96430fe0f914">json_object</a> **base, struct <a class="el" href="structjson__patch__error.html">json_patch_error</a> *patch_error)</td></tr>
  59. <tr class="separator:a134aaed1e732d029d34ce2d605f9ac8d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  60. </table>
  61. <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
  62. <div class="textblock"><p >JSON Patch (RFC 6902) implementation for manipulating JSON objects. </p>
  63. </div><h2 class="groupheader">Function Documentation</h2>
  64. <a id="a134aaed1e732d029d34ce2d605f9ac8d" name="a134aaed1e732d029d34ce2d605f9ac8d"></a>
  65. <h2 class="memtitle"><span class="permalink"><a href="#a134aaed1e732d029d34ce2d605f9ac8d">&#9670;&nbsp;</a></span>json_patch_apply()</h2>
  66. <div class="memitem">
  67. <div class="memproto">
  68. <table class="memname">
  69. <tr>
  70. <td class="memname"><a class="el" href="printbuf_8h.html#a2a31d5c00f3a4712f2d5d62aee66344e">JSON_EXPORT</a> int json_patch_apply </td>
  71. <td>(</td>
  72. <td class="paramtype">struct <a class="el" href="json__types_8h.html#af27907ced0f5a43409ad96430fe0f914">json_object</a> *&#160;</td>
  73. <td class="paramname"><em>copy_from</em>, </td>
  74. </tr>
  75. <tr>
  76. <td class="paramkey"></td>
  77. <td></td>
  78. <td class="paramtype">struct <a class="el" href="json__types_8h.html#af27907ced0f5a43409ad96430fe0f914">json_object</a> *&#160;</td>
  79. <td class="paramname"><em>patch</em>, </td>
  80. </tr>
  81. <tr>
  82. <td class="paramkey"></td>
  83. <td></td>
  84. <td class="paramtype">struct <a class="el" href="json__types_8h.html#af27907ced0f5a43409ad96430fe0f914">json_object</a> **&#160;</td>
  85. <td class="paramname"><em>base</em>, </td>
  86. </tr>
  87. <tr>
  88. <td class="paramkey"></td>
  89. <td></td>
  90. <td class="paramtype">struct <a class="el" href="structjson__patch__error.html">json_patch_error</a> *&#160;</td>
  91. <td class="paramname"><em>patch_error</em>&#160;</td>
  92. </tr>
  93. <tr>
  94. <td></td>
  95. <td>)</td>
  96. <td></td><td></td>
  97. </tr>
  98. </table>
  99. </div><div class="memdoc">
  100. <p >Apply the JSON patch to the base object. The patch object must be formatted as per RFC 6902, i.e. a json_type_array containing patch operations. If the patch is not correctly formatted, an error will be returned.</p>
  101. <p >The json_object at *base will be modified in place. Exactly one of *base or copy_from must be non-NULL. If *base is NULL, a new copy of copy_from will allocated and populated using <a class="el" href="json__object_8h.html#aaac16505f13bc56accfad82604d8bcdc">json_object_deep_copy()</a>. In this case <a class="el" href="json__object_8h.html#afabf61f932cd64a4122ca8092452eed5">json_object_put()</a> <em>must</em> be used to free *base even if the overall patching operation fails.</p>
  102. <p >If anything fails during patching a negative value will be returned, and patch_error (if non-NULL) will be populated with error details.</p>
  103. <dl class="params"><dt>Parameters</dt><dd>
  104. <table class="params">
  105. <tr><td class="paramname">base</td><td>a pointer to the JSON object which to patch </td></tr>
  106. <tr><td class="paramname">patch</td><td>the JSON object that describes the patch to be applied </td></tr>
  107. <tr><td class="paramname">copy_from</td><td>a JSON object to copy to *base </td></tr>
  108. <tr><td class="paramname">patch_error</td><td>optional, details about errors</td></tr>
  109. </table>
  110. </dd>
  111. </dl>
  112. <dl class="section return"><dt>Returns</dt><dd>negative if an error (or not found), or 0 if patch completely applied </dd></dl>
  113. </div>
  114. </div>
  115. </div><!-- contents -->
  116. <!-- start footer part -->
  117. <hr class="footer"/><address class="footer"><small>
  118. Generated on Sun Sep 15 2024 16:22:28 for json-c by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.9.4
  119. </small></address>
  120. </body>
  121. </html>