diff options
-rw-r--r-- | a85c798f91bfef796116f3ebf5e5e7e479c8683f.patch | 36 | ||||
-rw-r--r-- | compat_reports/0.11.0-RC1_to_0.11.0-RC2/compat_report.html | 473 | ||||
-rw-r--r-- | compat_reports/0.9.5_to_0.11.0-RC2/compat_report.html | 893 | ||||
-rw-r--r-- | librdkafka.spec | 10 |
4 files changed, 1371 insertions, 41 deletions
diff --git a/a85c798f91bfef796116f3ebf5e5e7e479c8683f.patch b/a85c798f91bfef796116f3ebf5e5e7e479c8683f.patch deleted file mode 100644 index 4956dba..0000000 --- a/a85c798f91bfef796116f3ebf5e5e7e479c8683f.patch +++ /dev/null @@ -1,36 +0,0 @@ -From a85c798f91bfef796116f3ebf5e5e7e479c8683f Mon Sep 17 00:00:00 2001 -From: Magnus Edenhill <magnus@edenhill.se> -Date: Thu, 29 Jun 2017 10:35:23 +0200 -Subject: [PATCH] configure crc32 for x32: try to avoid dead-code removal - ---- - configure.librdkafka | 4 ++++ - 1 file changed, 4 insertions(+) - -diff --git a/configure.librdkafka b/configure.librdkafka -index 903b0276..923dd48f 100644 ---- a/configure.librdkafka -+++ b/configure.librdkafka -@@ -86,11 +86,13 @@ function checks { - mkl_compile_check crc32chw WITH_CRC32C_HW disable CC "" \ - " - #include <inttypes.h> -+#include <stdio.h> - #define LONGx1 \"8192\" - #define LONGx2 \"16384\" - void foo (void) { - const char *n = \"abcdefghijklmnopqrstuvwxyz0123456789\"; - uint64_t c0 = 0, c1 = 1, c2 = 2; -+ uint64_t s; - uint32_t eax = 1, ecx; - __asm__(\"cpuid\" - : \"=c\"(ecx) -@@ -104,6 +106,8 @@ void foo (void) { - \"crc32q\t\" LONGx2 \"(%3), %2\" - : \"=r\"(c0), \"=r\"(c1), \"=r\"(c2) - : \"r\"(n), \"0\"(c0), \"1\"(c1), \"2\"(c2)); -+ s = c0 + c1 + c2; -+ printf(\"avoiding unused code removal by printing %d, %d, %d\n\", (int)s, (int)eax, (int)ecx); - } - " - diff --git a/compat_reports/0.11.0-RC1_to_0.11.0-RC2/compat_report.html b/compat_reports/0.11.0-RC1_to_0.11.0-RC2/compat_report.html new file mode 100644 index 0000000..f1a4e0d --- /dev/null +++ b/compat_reports/0.11.0-RC1_to_0.11.0-RC2/compat_report.html @@ -0,0 +1,473 @@ +<!-- kind:binary;verdict:compatible;affected:0;added:0;removed:0;type_problems_high:0;type_problems_medium:0;type_problems_low:0;interface_problems_high:0;interface_problems_medium:0;interface_problems_low:0;changed_constants:0;tool_version:2.0 --> +<!-- kind:source;verdict:compatible;affected:0;added:0;removed:0;type_problems_high:0;type_problems_medium:0;type_problems_low:0;interface_problems_high:0;interface_problems_medium:0;interface_problems_low:0;changed_constants:0;tool_version:2.0 --> +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> +<head> +<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> +<meta name="keywords" content="librdkafka, compatibility, API, ABI, report" /> +<meta name="description" content="API/ABI compatibility report for the librdkafka library between 0.11.0-RC1 and 0.11.0-RC2 versions" /> +<title>librdkafka: 0.11.0-RC1 to 0.11.0-RC2 compatibility report</title> +<style type="text/css"> +body { + font-family:Arial, sans-serif; + background-color:White; + color:Black; +} +hr { + color:Black; + background-color:Black; + height:1px; + border:0; +} +h1 { + margin-bottom:0px; + padding-bottom:0px; + font-size:1.625em; +} +h2 { + margin-bottom:0px; + padding-bottom:0px; + font-size:1.25em; + white-space:nowrap; +} +span.section { + font-weight:bold; + cursor:pointer; + color:#003E69; + white-space:nowrap; + margin-left:0.3125em; +} +span.new_sign { + font-weight:bold; + margin-left:1.65em; + color:#003E69; +} +span.new_sign_lbl { + margin-left:3em; + font-size:1em; + color:Black; +} +span:hover.section { + color:#336699; +} +span.sect_aff { + cursor:pointer; + padding-left:1.55em; + font-size:0.875em; + color:#cc3300; +} +span.sect_info { + cursor:pointer; + padding-left:1.55em; + font-size:0.875em; + color:Black; +} +span.ext { + font-weight:100; +} +span.h_name { + color:#cc3300; + font-size:0.875em; + font-weight:bold; +} +div.h_list, div.lib_list { + font-size:0.94em; + padding-left:0.4em; +} +span.ns { + color:#408080; + font-size:0.94em; +} +span.lib_name { + color:Green; + font-size:0.875em; + font-weight:bold; +} +span.iname { + font-weight:bold; + color:#003E69; + margin-left:0.3125em; +} +span.iname_b { + font-weight:bold; +} +span.iname_a { + color:#333333; + font-weight:bold; + font-size:0.94em; +} +span.sym_p { + font-weight:normal; + white-space:normal; +} +span.sym_pd { + white-space:normal; +} +span.sym_p span, span.sym_pd span { + white-space:nowrap; +} +div.affect { + padding-left:1em; + padding-bottom:10px; + font-size:0.87em; + font-style:italic; + line-height:0.9em; +} +div.affected { + padding-left:1.9em; + padding-top:10px; +} +table.ptable { + border-collapse:collapse; + border:1px outset black; + margin-left:0.95em; + margin-top:3px; + margin-bottom:3px; + width:56.25em; +} +table.ptable td { + border:1px solid gray; + padding:3px; + font-size:0.875em; + text-align:left; + vertical-align:top; + max-width:28em; + word-wrap:break-word; +} +table.ptable th.pn { + width:2%; +} +table.ptable th.chg { + width:47%; +} +table.vtable { + border-collapse:collapse; + border:1px outset black; + margin-left:1.9em; + margin-top:0.7em; +} +table.vtable td { + border:1px solid gray; + padding:3px; + font-size:0.875em; + vertical-align:top; + max-width:450px; + word-wrap:break-word; +} +table.ptable th, table.vtable th { + background-color:#eeeeee; + font-weight:bold; + color:#333333; + font-family:Verdana, Arial; + font-size:0.875em; + border:1px solid gray; + text-align:center; + vertical-align:top; + white-space:nowrap; + padding:3px; +} +table.summary { + border-collapse:collapse; + border:1px outset black; +} +table.summary th { + background-color:#eeeeee; + font-weight:100; + text-align:left; + font-size:0.94em; + white-space:nowrap; + border:1px inset gray; + padding:3px; +} +table.summary td { + text-align:right; + white-space:nowrap; + border:1px inset gray; + padding:3px 5px 3px 10px; +} +span.mngl { + padding-left:1em; + font-size:0.875em; + cursor:text; + color:#444444; + font-weight:bold; +} +span.pleft { + padding-left:2.5em; +} +span.sym_ver { + color:#333333; + white-space:nowrap; + font-family:"DejaVu Sans Mono", Monospace; +} +span.attr { + color:#333333; + font-weight:100; +} +span.color_p { + font-style:italic; + color:Brown; +} +span.p { + font-style:italic; +} +span.fp { + font-style:italic; + background-color:#DCDCDC; +} +span.ttype { + font-weight:100; +} +span.nowrap { + white-space:nowrap; +} +span.value { + font-weight:bold; +} +.passed { + background-color:#CCFFCC; + font-weight:100; +} +.warning { + background-color:#F4F4AF; + font-weight:100; +} +.failed { + background-color:#FFCCCC; + font-weight:100; +} +.new { + background-color:#C6DEFF; + font-weight:100; +} +.compatible { + background-color:#CCFFCC; + font-weight:100; +} +.almost_compatible { + background-color:#FFDAA3; + font-weight:100; +} +.incompatible { + background-color:#FFCCCC; + font-weight:100; +} +.gray { + background-color:#DCDCDC; + font-weight:100; +} +.top_ref { + font-size:0.69em; +} +.footer { + font-size:0.75em; +} + +.tabset { + float:left; +} +a.tab { + border:1px solid Black; + float:left; + margin:0px 5px -1px 0px; + padding:3px 5px 3px 5px; + position:relative; + font-size:0.875em; + background-color:#DDD; + text-decoration:none; + color:Black; +} +a.disabled:hover +{ + color:Black; + background:#EEE; +} +a.active:hover +{ + color:Black; + background:White; +} +a.active { + border-bottom-color:White; + background-color:White; +} +div.tab { + border-top:1px solid Black; + padding:0px; + width:100%; + clear:both; +} +</style> +<script type="text/javascript" language="JavaScript"> +<!-- +function showContent(header, id) +{ + e = document.getElementById(id); + if(e.style.display == 'none') + { + e.style.display = 'block'; + e.style.visibility = 'visible'; + header.innerHTML = header.innerHTML.replace(/\[[^0-9 ]\]/gi,"[−]"); + } + else + { + e.style.display = 'none'; + e.style.visibility = 'hidden'; + header.innerHTML = header.innerHTML.replace(/\[[^0-9 ]\]/gi,"[+]"); + } +} +function initTabs() +{ + var url = window.location.href; + if(url.indexOf('_Source_')!=-1 || url.indexOf('#Source')!=-1) + { + var tab1 = document.getElementById('BinaryID'); + var tab2 = document.getElementById('SourceID'); + tab1.className='tab disabled'; + tab2.className='tab active'; + } + var sets = document.getElementsByTagName('div'); + for (var i = 0; i < sets.length; i++) + { + if (sets[i].className.indexOf('tabset') != -1) + { + var tabs = []; + var links = sets[i].getElementsByTagName('a'); + for (var j = 0; j < links.length; j++) + { + if (links[j].className.indexOf('tab') != -1) + { + tabs.push(links[j]); + links[j].tabs = tabs; + var tab = document.getElementById(links[j].href.substr(links[j].href.indexOf('#') + 1)); + //reset all tabs on start + if (tab) + { + if (links[j].className.indexOf('active')!=-1) { + tab.style.display = 'block'; + } + else { + tab.style.display = 'none'; + } + } + links[j].onclick = function() + { + var tab = document.getElementById(this.href.substr(this.href.indexOf('#') + 1)); + if (tab) + { + //reset all tabs before change + for (var k = 0; k < this.tabs.length; k++) + { + document.getElementById(this.tabs[k].href.substr(this.tabs[k].href.indexOf('#') + 1)).style.display = 'none'; + this.tabs[k].className = this.tabs[k].className.replace('active', 'disabled'); + } + this.className = 'tab active'; + tab.style.display = 'block'; + // window.location.hash = this.id.replace('ID', ''); + return false; + } + } + } + } + } + } + if(url.indexOf('#')!=-1) { + location.href=location.href; + } +} +if (window.addEventListener) window.addEventListener('load', initTabs, false); +else if (window.attachEvent) window.attachEvent('onload', initTabs); +--> +</script> +</head> +<body><a name='Source'></a><a name='Binary'></a><a name='Top'></a><h1>API compatibility report for the <span style='color:Blue;'>librdkafka</span> library between <span style='color:Red;'>0.11.0-RC1</span> and <span style='color:Red;'>0.11.0-RC2</span> versions on <span style='color:Blue;'>x86_64</span></h1> + + <br/> + <div class='tabset'> + <a id='BinaryID' href='#BinaryTab' class='tab active'>Binary<br/>Compatibility</a> + <a id='SourceID' href='#SourceTab' style='margin-left:3px' class='tab disabled'>Source<br/>Compatibility</a> + </div><div id='BinaryTab' class='tab'> +<h2>Test Info</h2><hr/> +<table class='summary'> +<tr><th>Library Name</th><td>librdkafka</td></tr> +<tr><th>Version #1</th><td>0.11.0-RC1</td></tr> +<tr><th>Version #2</th><td>0.11.0-RC2</td></tr> +<tr><th>Arch</th><td>x86_64</td></tr> +<tr><th>GCC Version</th><td>6.3.1</td></tr> +<tr><th>Subject</th><td width='150px'>Binary Compatibility</td></tr> +</table> +<h2>Test Results</h2><hr/> +<table class='summary'><tr><th>Total Header Files</th><td><a href='#Headers' style='color:Blue;'>1</a></td></tr> +<tr><th>Total Libraries</th><td><a href='#Libs' style='color:Blue;'>1</a></td></tr> +<tr><th>Total Symbols / Types</th><td>154 / 69</td></tr> +<tr><th>Compatibility</th> +<td class='compatible'>100%</td> +</tr> +</table> +<h2>Problem Summary</h2><hr/> +<table class='summary'><tr><th></th><th style='text-align:center;'>Severity</th><th style='text-align:center;'>Count</th></tr><tr><th>Added Symbols</th><td>-</td><td>0</td></tr> +<tr><th>Removed Symbols</th><td>High</td><td>0</td></tr> +<tr><th rowspan='3'>Problems with<br/>Data Types</th><td>High</td><td>0</td></tr> +<tr><td>Medium</td><td>0</td></tr> +<tr><td>Low</td><td>0</td></tr> +<tr><th rowspan='3'>Problems with<br/>Symbols</th><td>High</td><td>0</td></tr> +<tr><td>Medium</td><td>0</td></tr> +<tr><td>Low</td><td>0</td></tr> +<tr><th>Problems with<br/>Constants</th><td>Low</td><td>0</td></tr> +</table> + +<a name='Headers'></a><h2>Header Files <span class='gray'> 1 </span></h2><hr/> +<div class='h_list'> +rdkafka.h<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Libs'></a><h2>Libraries <span class='gray'> 1 </span></h2><hr/> +<div class='lib_list'> +librdkafka.so.1<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<br/><br/><br/></div><div id='SourceTab' class='tab'> +<h2>Test Info</h2><hr/> +<table class='summary'> +<tr><th>Library Name</th><td>librdkafka</td></tr> +<tr><th>Version #1</th><td>0.11.0-RC1</td></tr> +<tr><th>Version #2</th><td>0.11.0-RC2</td></tr> +<tr><th>Arch</th><td>x86_64</td></tr> +<tr><th>Subject</th><td width='150px'>Source Compatibility</td></tr> +</table> +<h2>Test Results</h2><hr/> +<table class='summary'><tr><th>Total Header Files</th><td><a href='#Headers' style='color:Blue;'>1</a></td></tr> +<tr><th>Total Libraries</th><td><a href='#Libs' style='color:Blue;'>1</a></td></tr> +<tr><th>Total Symbols / Types</th><td>155 / 69</td></tr> +<tr><th>Compatibility</th> +<td class='compatible'>100%</td> +</tr> +</table> +<h2>Problem Summary</h2><hr/> +<table class='summary'><tr><th></th><th style='text-align:center;'>Severity</th><th style='text-align:center;'>Count</th></tr><tr><th>Added Symbols</th><td>-</td><td>0</td></tr> +<tr><th>Removed Symbols</th><td>High</td><td>0</td></tr> +<tr><th rowspan='3'>Problems with<br/>Data Types</th><td>High</td><td>0</td></tr> +<tr><td>Medium</td><td>0</td></tr> +<tr><td>Low</td><td>0</td></tr> +<tr><th rowspan='3'>Problems with<br/>Symbols</th><td>High</td><td>0</td></tr> +<tr><td>Medium</td><td>0</td></tr> +<tr><td>Low</td><td>0</td></tr> +<tr><th>Problems with<br/>Constants</th><td>Low</td><td>0</td></tr> +</table> + +<a name='Headers'></a><h2>Header Files <span class='gray'> 1 </span></h2><hr/> +<div class='h_list'> +rdkafka.h<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Libs'></a><h2>Libraries <span class='gray'> 1 </span></h2><hr/> +<div class='lib_list'> +librdkafka.so.1<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<br/><br/><br/></div><hr/> +<div class='footer' align='right'><i>Generated by <a href='https://github.com/lvc/abi-compliance-checker'>ABI Compliance Checker</a> 2.0  </i> +</div> +<br/> + +</body></html> diff --git a/compat_reports/0.9.5_to_0.11.0-RC2/compat_report.html b/compat_reports/0.9.5_to_0.11.0-RC2/compat_report.html new file mode 100644 index 0000000..0576187 --- /dev/null +++ b/compat_reports/0.9.5_to_0.11.0-RC2/compat_report.html @@ -0,0 +1,893 @@ +<!-- kind:binary;verdict:compatible;affected:0;added:15;removed:0;type_problems_high:0;type_problems_medium:0;type_problems_low:1;interface_problems_high:0;interface_problems_medium:0;interface_problems_low:0;changed_constants:0;type_changes_other:17;constant_changes_other:1;tool_version:2.0 --> +<!-- kind:source;verdict:compatible;affected:0;added:15;removed:0;type_problems_high:0;type_problems_medium:0;type_problems_low:0;interface_problems_high:0;interface_problems_medium:0;interface_problems_low:0;changed_constants:1;type_changes_other:18;constant_changes_other:1;tool_version:2.0 --> +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> +<head> +<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> +<meta name="keywords" content="librdkafka, compatibility, API, ABI, report" /> +<meta name="description" content="API/ABI compatibility report for the librdkafka library between 0.9.5 and 0.11.0-RC2 versions" /> +<title>librdkafka: 0.9.5 to 0.11.0-RC2 compatibility report</title> +<style type="text/css"> +body { + font-family:Arial, sans-serif; + background-color:White; + color:Black; +} +hr { + color:Black; + background-color:Black; + height:1px; + border:0; +} +h1 { + margin-bottom:0px; + padding-bottom:0px; + font-size:1.625em; +} +h2 { + margin-bottom:0px; + padding-bottom:0px; + font-size:1.25em; + white-space:nowrap; +} +span.section { + font-weight:bold; + cursor:pointer; + color:#003E69; + white-space:nowrap; + margin-left:0.3125em; +} +span.new_sign { + font-weight:bold; + margin-left:1.65em; + color:#003E69; +} +span.new_sign_lbl { + margin-left:3em; + font-size:1em; + color:Black; +} +span:hover.section { + color:#336699; +} +span.sect_aff { + cursor:pointer; + padding-left:1.55em; + font-size:0.875em; + color:#cc3300; +} +span.sect_info { + cursor:pointer; + padding-left:1.55em; + font-size:0.875em; + color:Black; +} +span.ext { + font-weight:100; +} +span.h_name { + color:#cc3300; + font-size:0.875em; + font-weight:bold; +} +div.h_list, div.lib_list { + font-size:0.94em; + padding-left:0.4em; +} +span.ns { + color:#408080; + font-size:0.94em; +} +span.lib_name { + color:Green; + font-size:0.875em; + font-weight:bold; +} +span.iname { + font-weight:bold; + color:#003E69; + margin-left:0.3125em; +} +span.iname_b { + font-weight:bold; +} +span.iname_a { + color:#333333; + font-weight:bold; + font-size:0.94em; +} +span.sym_p { + font-weight:normal; + white-space:normal; +} +span.sym_pd { + white-space:normal; +} +span.sym_p span, span.sym_pd span { + white-space:nowrap; +} +div.affect { + padding-left:1em; + padding-bottom:10px; + font-size:0.87em; + font-style:italic; + line-height:0.9em; +} +div.affected { + padding-left:1.9em; + padding-top:10px; +} +table.ptable { + border-collapse:collapse; + border:1px outset black; + margin-left:0.95em; + margin-top:3px; + margin-bottom:3px; + width:56.25em; +} +table.ptable td { + border:1px solid gray; + padding:3px; + font-size:0.875em; + text-align:left; + vertical-align:top; + max-width:28em; + word-wrap:break-word; +} +table.ptable th.pn { + width:2%; +} +table.ptable th.chg { + width:47%; +} +table.vtable { + border-collapse:collapse; + border:1px outset black; + margin-left:1.9em; + margin-top:0.7em; +} +table.vtable td { + border:1px solid gray; + padding:3px; + font-size:0.875em; + vertical-align:top; + max-width:450px; + word-wrap:break-word; +} +table.ptable th, table.vtable th { + background-color:#eeeeee; + font-weight:bold; + color:#333333; + font-family:Verdana, Arial; + font-size:0.875em; + border:1px solid gray; + text-align:center; + vertical-align:top; + white-space:nowrap; + padding:3px; +} +table.summary { + border-collapse:collapse; + border:1px outset black; +} +table.summary th { + background-color:#eeeeee; + font-weight:100; + text-align:left; + font-size:0.94em; + white-space:nowrap; + border:1px inset gray; + padding:3px; +} +table.summary td { + text-align:right; + white-space:nowrap; + border:1px inset gray; + padding:3px 5px 3px 10px; +} +span.mngl { + padding-left:1em; + font-size:0.875em; + cursor:text; + color:#444444; + font-weight:bold; +} +span.pleft { + padding-left:2.5em; +} +span.sym_ver { + color:#333333; + white-space:nowrap; + font-family:"DejaVu Sans Mono", Monospace; +} +span.attr { + color:#333333; + font-weight:100; +} +span.color_p { + font-style:italic; + color:Brown; +} +span.p { + font-style:italic; +} +span.fp { + font-style:italic; + background-color:#DCDCDC; +} +span.ttype { + font-weight:100; +} +span.nowrap { + white-space:nowrap; +} +span.value { + font-weight:bold; +} +.passed { + background-color:#CCFFCC; + font-weight:100; +} +.warning { + background-color:#F4F4AF; + font-weight:100; +} +.failed { + background-color:#FFCCCC; + font-weight:100; +} +.new { + background-color:#C6DEFF; + font-weight:100; +} +.compatible { + background-color:#CCFFCC; + font-weight:100; +} +.almost_compatible { + background-color:#FFDAA3; + font-weight:100; +} +.incompatible { + background-color:#FFCCCC; + font-weight:100; +} +.gray { + background-color:#DCDCDC; + font-weight:100; +} +.top_ref { + font-size:0.69em; +} +.footer { + font-size:0.75em; +} + +.tabset { + float:left; +} +a.tab { + border:1px solid Black; + float:left; + margin:0px 5px -1px 0px; + padding:3px 5px 3px 5px; + position:relative; + font-size:0.875em; + background-color:#DDD; + text-decoration:none; + color:Black; +} +a.disabled:hover +{ + color:Black; + background:#EEE; +} +a.active:hover +{ + color:Black; + background:White; +} +a.active { + border-bottom-color:White; + background-color:White; +} +div.tab { + border-top:1px solid Black; + padding:0px; + width:100%; + clear:both; +} +</style> +<script type="text/javascript" language="JavaScript"> +<!-- +function showContent(header, id) +{ + e = document.getElementById(id); + if(e.style.display == 'none') + { + e.style.display = 'block'; + e.style.visibility = 'visible'; + header.innerHTML = header.innerHTML.replace(/\[[^0-9 ]\]/gi,"[−]"); + } + else + { + e.style.display = 'none'; + e.style.visibility = 'hidden'; + header.innerHTML = header.innerHTML.replace(/\[[^0-9 ]\]/gi,"[+]"); + } +} +function initTabs() +{ + var url = window.location.href; + if(url.indexOf('_Source_')!=-1 || url.indexOf('#Source')!=-1) + { + var tab1 = document.getElementById('BinaryID'); + var tab2 = document.getElementById('SourceID'); + tab1.className='tab disabled'; + tab2.className='tab active'; + } + var sets = document.getElementsByTagName('div'); + for (var i = 0; i < sets.length; i++) + { + if (sets[i].className.indexOf('tabset') != -1) + { + var tabs = []; + var links = sets[i].getElementsByTagName('a'); + for (var j = 0; j < links.length; j++) + { + if (links[j].className.indexOf('tab') != -1) + { + tabs.push(links[j]); + links[j].tabs = tabs; + var tab = document.getElementById(links[j].href.substr(links[j].href.indexOf('#') + 1)); + //reset all tabs on start + if (tab) + { + if (links[j].className.indexOf('active')!=-1) { + tab.style.display = 'block'; + } + else { + tab.style.display = 'none'; + } + } + links[j].onclick = function() + { + var tab = document.getElementById(this.href.substr(this.href.indexOf('#') + 1)); + if (tab) + { + //reset all tabs before change + for (var k = 0; k < this.tabs.length; k++) + { + document.getElementById(this.tabs[k].href.substr(this.tabs[k].href.indexOf('#') + 1)).style.display = 'none'; + this.tabs[k].className = this.tabs[k].className.replace('active', 'disabled'); + } + this.className = 'tab active'; + tab.style.display = 'block'; + // window.location.hash = this.id.replace('ID', ''); + return false; + } + } + } + } + } + } + if(url.indexOf('#')!=-1) { + location.href=location.href; + } +} +if (window.addEventListener) window.addEventListener('load', initTabs, false); +else if (window.attachEvent) window.attachEvent('onload', initTabs); +--> +</script> +</head> +<body><a name='Source'></a><a name='Binary'></a><a name='Top'></a><h1>API compatibility report for the <span style='color:Blue;'>librdkafka</span> library between <span style='color:Red;'>0.9.5</span> and <span style='color:Red;'>0.11.0-RC2</span> versions on <span style='color:Blue;'>x86_64</span></h1> + + <br/> + <div class='tabset'> + <a id='BinaryID' href='#BinaryTab' class='tab active'>Binary<br/>Compatibility</a> + <a id='SourceID' href='#SourceTab' style='margin-left:3px' class='tab disabled'>Source<br/>Compatibility</a> + </div><div id='BinaryTab' class='tab'> +<h2>Test Info</h2><hr/> +<table class='summary'> +<tr><th>Library Name</th><td>librdkafka</td></tr> +<tr><th>Version #1</th><td>0.9.5</td></tr> +<tr><th>Version #2</th><td>0.11.0-RC2</td></tr> +<tr><th>Arch</th><td>x86_64</td></tr> +<tr><th>GCC Version</th><td>6.3.1</td></tr> +<tr><th>Subject</th><td width='150px'>Binary Compatibility</td></tr> +</table> +<h2>Test Results</h2><hr/> +<table class='summary'><tr><th>Total Header Files</th><td><a href='#Headers' style='color:Blue;'>1</a></td></tr> +<tr><th>Total Libraries</th><td><a href='#Libs' style='color:Blue;'>1</a></td></tr> +<tr><th>Total Symbols / Types</th><td>139 / 62</td></tr> +<tr><th>Compatibility</th> +<td class='compatible'>100%</td> +</tr> +</table> +<h2>Problem Summary</h2><hr/> +<table class='summary'><tr><th></th><th style='text-align:center;'>Severity</th><th style='text-align:center;'>Count</th></tr><tr><th>Added Symbols</th><td>-</td><td class='new'><a href='#Binary_Added' style='color:Blue;'>15</a></td></tr> +<tr><th>Removed Symbols</th><td>High</td><td>0</td></tr> +<tr><th rowspan='3'>Problems with<br/>Data Types</th><td>High</td><td>0</td></tr> +<tr><td>Medium</td><td>0</td></tr> +<tr><td>Low</td><td class='warning'><a href='#Type_Binary_Problems_Low' style='color:Blue;'>1</a></td></tr> +<tr><th rowspan='3'>Problems with<br/>Symbols</th><td>High</td><td>0</td></tr> +<tr><td>Medium</td><td>0</td></tr> +<tr><td>Low</td><td>0</td></tr> +<tr><th>Problems with<br/>Constants</th><td>Low</td><td>0</td></tr> +<tr><th>Other Changes<br/>in Data Types</th><td>-</td><td class='passed'><a href='#Other_Binary_Changes_In_Types' style='color:Blue;'>17</a></td></tr> +<tr><th>Other Changes<br/>in Constants</th><td>-</td><td class='passed'><a href='#Other_Binary_Changes_In_Constants' style='color:Blue;'>1</a></td></tr> +</table> + +<a name='Binary_Added'></a><h2>Added Symbols <span class='new'> 15 </span></h2><hr/> +<span class='h_name'>rdkafka.h</span>, <span class='lib_name'>librdkafka.so.1</span><br/> +<span class="iname">rd_kafka_clusterid <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>int <span class='color_p'>timeout_ms</span></span> )</span></span><br/> +<span class="iname">rd_kafka_conf_interceptor_add_on_conf_destroy <span class='sym_p'><span>( rd_kafka_conf_t* <span class='color_p'>conf</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_conf_destroy</span>)(void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_conf_interceptor_add_on_conf_dup <span class='sym_p'><span>( rd_kafka_conf_t* <span class='color_p'>conf</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_conf_dup</span>)(rd_kafka_conf_t*, rd_kafka_conf_t const*, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_conf_interceptor_add_on_conf_set <span class='sym_p'><span>( rd_kafka_conf_t* <span class='color_p'>conf</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_conf_res_t(*<span class='color_p'>on_conf_set</span>)(rd_kafka_conf_t*, char const*, char const*, char*, size_t, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_conf_interceptor_add_on_new <span class='sym_p'><span>( rd_kafka_conf_t* <span class='color_p'>conf</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_new</span>)(rd_kafka_t*, void*, char*, size_t)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_event_stats <span class='sym_p'><span>( rd_kafka_event_t* <span class='color_p'>rkev</span></span> )</span></span><br/> +<span class="iname">rd_kafka_interceptor_add_on_acknowledgement <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_acknowledgement</span>)(rd_kafka_t*, rd_kafka_message_t*, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_interceptor_add_on_commit <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_commit</span>)(rd_kafka_t*, rd_kafka_topic_partition_list_t const*, enum rd_kafka_resp_err_t, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_interceptor_add_on_consume <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_consume</span>)(rd_kafka_t*, rd_kafka_message_t*, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_interceptor_add_on_destroy <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_destroy</span>)(rd_kafka_t*, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_interceptor_add_on_send <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_send</span>)(rd_kafka_t*, rd_kafka_message_t*, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_message_latency <span class='sym_p'><span>( rd_kafka_message_t const* <span class='color_p'>rkmessage</span></span> )</span></span><br/> +<span class="iname">rd_kafka_offsets_store <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_topic_partition_list_t* <span class='color_p'>offsets</span></span> )</span></span><br/> +<span class="iname">rd_kafka_type <span class='sym_p'><span>( rd_kafka_t const* <span class='color_p'>rk</span></span> )</span></span><br/> +<span class="iname">rd_kafka_unittest <span class='sym_p'>( )</span></span><br/> +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Low_Risk_Binary_Problems'></a><a name='Type_Binary_Problems_Low'></a> +<h2>Problems with Data Types, Low Severity <span class='warning'> 1 </span></h2><hr/> +<span class='h_name'>rdkafka.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_1')"> +<span class='ext'>[+]</span> <span class='ttype'>enum</span> rd_kafka_resp_err_t <span class='warning'> 1 </span></span> +<br/> +<div id="c_1" style="display:none;"> +<table class='ptable'><tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th></tr><tr> +<th>1</th> +<td>Value of member <b>RD_KAFKA_RESP_ERR_END_ALL</b> has been changed from <b>44</b> to <b>56</b>.</td> +<td>Applications may execute a wrong branch of code in the library and therefore change the behavior.</td> +</tr> +</table> +<span class="sect_aff" onclick="javascript:showContent(this, 'c_2')"> +[+] affected symbols: 62 (44.6%)</span> +<div id="c_2" style="display:none;"> +<div class='affected'><span class='iname_a'>rd_kafka_assign <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>partitions</span></span> )</span></span><br/> +<div class='affect'>Field 'partitions.elems.err' in 2nd parameter 'partitions' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_assignment <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t** <span class='fp'>partitions</span></span> )</span></span><br/> +<div class='affect'>Field 'partitions.elems.err' in 2nd parameter 'partitions' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_commit <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>offsets</span></span>, <span>int <i>async</i></span> )</span></span><br/> +<div class='affect'>Field 'offsets.elems.err' in 2nd parameter 'offsets' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_commit_message <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_message_t const* <span class='fp'>rkmessage</span></span>, <span>int <i>async</i></span> )</span></span><br/> +<div class='affect'>Field 'rkmessage.err' in 2nd parameter 'rkmessage' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_commit_queue <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <i>offsets</i></span>, <span>rd_kafka_queue_t* <i>rkqu</i></span>, <span>void(*<span class='fp'>cb</span>)(rd_kafka_t*, enum rd_kafka_resp_err_t, rd_kafka_topic_partition_list_t*, void*)</span>, <span>void* <i>opaque</i></span> )</span></span><br/> +<div class='affect'>Field 'cb.p1' in 4th parameter 'cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_committed <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t* <span class='fp'>partitions</span></span>, <span>int <i>timeout_ms</i></span> )</span></span><br/> +<div class='affect'>Field 'partitions.elems.err' in 2nd parameter 'partitions' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_consume_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>consume_cb</span>)(rd_kafka_message_t*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'consume_cb.p0.err' in 2nd parameter 'consume_cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_dr_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>dr_cb</span>)(rd_kafka_t*, void*, size_t, enum rd_kafka_resp_err_t, void*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'dr_cb.p3' in 2nd parameter 'dr_cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_dr_msg_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>dr_msg_cb</span>)(rd_kafka_t*, rd_kafka_message_t const*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'dr_msg_cb.p1.err' in 2nd parameter 'dr_msg_cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_offset_commit_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>offset_commit_cb</span>)(rd_kafka_t*, enum rd_kafka_resp_err_t, rd_kafka_topic_partition_list_t*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'offset_commit_cb.p1' in 2nd parameter 'offset_commit_cb' has base type 'enum rd_kafka_resp_err_t'.</div> + <b>...</b> +<br/> +</div> +</div> +<br/><br/></div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Other_Binary_Changes'></a><a name='Other_Binary_Changes_In_Types'></a> +<h2>Other Changes in Data Types <span class='passed'> 17 </span></h2><hr/> +<span class='h_name'>rdkafka.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_3')"> +<span class='ext'>[+]</span> <span class='ttype'>enum</span> rd_kafka_resp_err_t <span class='passed'> 17 </span></span> +<br/> +<div id="c_3" style="display:none;"> +<table class='ptable'><tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th></tr><tr> +<th>1</th> +<td>The member <b>RD_KAFKA_RESP_ERR_CONCURRENT_TRANSACTIONS</b> with value <b>51</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>2</th> +<td>The member <b>RD_KAFKA_RESP_ERR_DUPLICATE_SEQUENCE_NUMBER</b> with value <b>46</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>3</th> +<td>The member <b>RD_KAFKA_RESP_ERR_INVALID_PRODUCER_EPOCH</b> with value <b>47</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>4</th> +<td>The member <b>RD_KAFKA_RESP_ERR_INVALID_PRODUCER_ID_MAPPING</b> with value <b>49</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>5</th> +<td>The member <b>RD_KAFKA_RESP_ERR_INVALID_TRANSACTION_TIMEOUT</b> with value <b>50</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>6</th> +<td>The member <b>RD_KAFKA_RESP_ERR_INVALID_TXN_STATE</b> with value <b>48</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>7</th> +<td>The member <b>RD_KAFKA_RESP_ERR_OPERATION_NOT_ATTEMPTED</b> with value <b>55</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>8</th> +<td>The member <b>RD_KAFKA_RESP_ERR_OUT_OF_ORDER_SEQUENCE_NUMBER</b> with value <b>45</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>9</th> +<td>The member <b>RD_KAFKA_RESP_ERR_POLICY_VIOLATION</b> with value <b>44</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>10</th> +<td>The member <b>RD_KAFKA_RESP_ERR_SECURITY_DISABLED</b> with value <b>54</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>11</th> +<td>The member <b>RD_KAFKA_RESP_ERR_TRANSACTIONAL_ID_AUTHORIZATION_FAILED</b> with value <b>53</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>12</th> +<td>The member <b>RD_KAFKA_RESP_ERR_TRANSACTION_COORDINATOR_FENCED</b> with value <b>52</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>13</th> +<td>The member <b>RD_KAFKA_RESP_ERR__INTR</b> with value <b>-163</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>14</th> +<td>The member <b>RD_KAFKA_RESP_ERR__KEY_DESERIALIZATION</b> with value <b>-160</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>15</th> +<td>The member <b>RD_KAFKA_RESP_ERR__KEY_SERIALIZATION</b> with value <b>-162</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>16</th> +<td>The member <b>RD_KAFKA_RESP_ERR__VALUE_DESERIALIZATION</b> with value <b>-159</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>17</th> +<td>The member <b>RD_KAFKA_RESP_ERR__VALUE_SERIALIZATION</b> with value <b>-161</b> has been added.</td> +<td>No effect.</td> +</tr> +</table> +<span class="sect_aff" onclick="javascript:showContent(this, 'c_4')"> +[+] affected symbols: 62 (44.6%)</span> +<div id="c_4" style="display:none;"> +<div class='affected'><span class='iname_a'>rd_kafka_assign <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>partitions</span></span> )</span></span><br/> +<div class='affect'>Field 'partitions.elems.err' in 2nd parameter 'partitions' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_assignment <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t** <span class='fp'>partitions</span></span> )</span></span><br/> +<div class='affect'>Field 'partitions.elems.err' in 2nd parameter 'partitions' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_commit <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>offsets</span></span>, <span>int <i>async</i></span> )</span></span><br/> +<div class='affect'>Field 'offsets.elems.err' in 2nd parameter 'offsets' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_commit_message <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_message_t const* <span class='fp'>rkmessage</span></span>, <span>int <i>async</i></span> )</span></span><br/> +<div class='affect'>Field 'rkmessage.err' in 2nd parameter 'rkmessage' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_commit_queue <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <i>offsets</i></span>, <span>rd_kafka_queue_t* <i>rkqu</i></span>, <span>void(*<span class='fp'>cb</span>)(rd_kafka_t*, enum rd_kafka_resp_err_t, rd_kafka_topic_partition_list_t*, void*)</span>, <span>void* <i>opaque</i></span> )</span></span><br/> +<div class='affect'>Field 'cb.p1' in 4th parameter 'cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_committed <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t* <span class='fp'>partitions</span></span>, <span>int <i>timeout_ms</i></span> )</span></span><br/> +<div class='affect'>Field 'partitions.elems.err' in 2nd parameter 'partitions' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_consume_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>consume_cb</span>)(rd_kafka_message_t*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'consume_cb.p0.err' in 2nd parameter 'consume_cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_dr_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>dr_cb</span>)(rd_kafka_t*, void*, size_t, enum rd_kafka_resp_err_t, void*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'dr_cb.p3' in 2nd parameter 'dr_cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_dr_msg_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>dr_msg_cb</span>)(rd_kafka_t*, rd_kafka_message_t const*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'dr_msg_cb.p1.err' in 2nd parameter 'dr_msg_cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_offset_commit_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>offset_commit_cb</span>)(rd_kafka_t*, enum rd_kafka_resp_err_t, rd_kafka_topic_partition_list_t*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'offset_commit_cb.p1' in 2nd parameter 'offset_commit_cb' has base type 'enum rd_kafka_resp_err_t'.</div> + <b>...</b> +<br/> +</div> +</div> +<br/><br/></div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Other_Binary_Changes_In_Constants'></a> +<h2>Other Changes in Constants <span class='passed'> 1 </span></h2><hr/> +<span class='h_name'>rdkafka.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_5')"> +<span class='ext'>[+]</span> RD_KAFKA_EVENT_STATS</span> +<br/> +<div id="c_5" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The constant <b>RD_KAFKA_EVENT_STATS</b> with value <b>0x40</b> has been added.</td> +<td>No effect.</td> +</tr> +</table> +<br/> +</div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Headers'></a><h2>Header Files <span class='gray'> 1 </span></h2><hr/> +<div class='h_list'> +rdkafka.h<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Libs'></a><h2>Libraries <span class='gray'> 1 </span></h2><hr/> +<div class='lib_list'> +librdkafka.so.1<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<br/><br/><br/></div><div id='SourceTab' class='tab'> +<h2>Test Info</h2><hr/> +<table class='summary'> +<tr><th>Library Name</th><td>librdkafka</td></tr> +<tr><th>Version #1</th><td>0.9.5</td></tr> +<tr><th>Version #2</th><td>0.11.0-RC2</td></tr> +<tr><th>Arch</th><td>x86_64</td></tr> +<tr><th>Subject</th><td width='150px'>Source Compatibility</td></tr> +</table> +<h2>Test Results</h2><hr/> +<table class='summary'><tr><th>Total Header Files</th><td><a href='#Headers' style='color:Blue;'>1</a></td></tr> +<tr><th>Total Libraries</th><td><a href='#Libs' style='color:Blue;'>1</a></td></tr> +<tr><th>Total Symbols / Types</th><td>140 / 62</td></tr> +<tr><th>Compatibility</th> +<td class='compatible'>100%</td> +</tr> +</table> +<h2>Problem Summary</h2><hr/> +<table class='summary'><tr><th></th><th style='text-align:center;'>Severity</th><th style='text-align:center;'>Count</th></tr><tr><th>Added Symbols</th><td>-</td><td class='new'><a href='#Source_Added' style='color:Blue;'>15</a></td></tr> +<tr><th>Removed Symbols</th><td>High</td><td>0</td></tr> +<tr><th rowspan='3'>Problems with<br/>Data Types</th><td>High</td><td>0</td></tr> +<tr><td>Medium</td><td>0</td></tr> +<tr><td>Low</td><td>0</td></tr> +<tr><th rowspan='3'>Problems with<br/>Symbols</th><td>High</td><td>0</td></tr> +<tr><td>Medium</td><td>0</td></tr> +<tr><td>Low</td><td>0</td></tr> +<tr><th>Problems with<br/>Constants</th><td>Low</td><td class='warning'><a href='#Constant_Source_Problems_Low' style='color:Blue;'>1</a></td></tr> +<tr><th>Other Changes<br/>in Data Types</th><td>-</td><td class='passed'><a href='#Other_Source_Changes_In_Types' style='color:Blue;'>18</a></td></tr> +<tr><th>Other Changes<br/>in Constants</th><td>-</td><td class='passed'><a href='#Other_Source_Changes_In_Constants' style='color:Blue;'>1</a></td></tr> +</table> + +<a name='Source_Added'></a><h2>Added Symbols <span class='new'> 15 </span></h2><hr/> +<span class='h_name'>rdkafka.h</span><br/> +<span class="iname">rd_kafka_clusterid <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>int <span class='color_p'>timeout_ms</span></span> )</span></span><br/> +<span class="iname">rd_kafka_conf_interceptor_add_on_conf_destroy <span class='sym_p'><span>( rd_kafka_conf_t* <span class='color_p'>conf</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_conf_destroy</span>)(void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_conf_interceptor_add_on_conf_dup <span class='sym_p'><span>( rd_kafka_conf_t* <span class='color_p'>conf</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_conf_dup</span>)(rd_kafka_conf_t*, rd_kafka_conf_t const*, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_conf_interceptor_add_on_conf_set <span class='sym_p'><span>( rd_kafka_conf_t* <span class='color_p'>conf</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_conf_res_t(*<span class='color_p'>on_conf_set</span>)(rd_kafka_conf_t*, char const*, char const*, char*, size_t, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_conf_interceptor_add_on_new <span class='sym_p'><span>( rd_kafka_conf_t* <span class='color_p'>conf</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_new</span>)(rd_kafka_t*, void*, char*, size_t)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_event_stats <span class='sym_p'><span>( rd_kafka_event_t* <span class='color_p'>rkev</span></span> )</span></span><br/> +<span class="iname">rd_kafka_interceptor_add_on_acknowledgement <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_acknowledgement</span>)(rd_kafka_t*, rd_kafka_message_t*, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_interceptor_add_on_commit <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_commit</span>)(rd_kafka_t*, rd_kafka_topic_partition_list_t const*, enum rd_kafka_resp_err_t, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_interceptor_add_on_consume <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_consume</span>)(rd_kafka_t*, rd_kafka_message_t*, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_interceptor_add_on_destroy <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_destroy</span>)(rd_kafka_t*, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_interceptor_add_on_send <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>char const* <span class='color_p'>ic_name</span></span>, <span>enum rd_kafka_resp_err_t(*<span class='color_p'>on_send</span>)(rd_kafka_t*, rd_kafka_message_t*, void*)</span>, <span>void* <span class='color_p'>ic_opaque</span></span> )</span></span><br/> +<span class="iname">rd_kafka_message_latency <span class='sym_p'><span>( rd_kafka_message_t const* <span class='color_p'>rkmessage</span></span> )</span></span><br/> +<span class="iname">rd_kafka_offsets_store <span class='sym_p'><span>( rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_topic_partition_list_t* <span class='color_p'>offsets</span></span> )</span></span><br/> +<span class="iname">rd_kafka_type <span class='sym_p'><span>( rd_kafka_t const* <span class='color_p'>rk</span></span> )</span></span><br/> +<span class="iname">rd_kafka_unittest <span class='sym_p'>( )</span></span><br/> +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Low_Risk_Source_Problems'></a><a name='Constant_Source_Problems_Low'></a> +<h2>Problems with Constants, Low Severity <span class='warning'> 1 </span></h2><hr/> +<span class='h_name'>rdkafka.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_6')"> +<span class='ext'>[+]</span> RD_KAFKA_VERSION</span> +<br/> +<div id="c_6" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The value of constant <b>RD_KAFKA_VERSION</b> has been changed from <b>0x000905ff</b> to <b>0x000b00c9</b>.</td> +<td>Recompilation of a client program may be broken.</td> +</tr> +</table> +<br/> +</div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Other_Source_Changes'></a><a name='Other_Source_Changes_In_Types'></a> +<h2>Other Changes in Data Types <span class='passed'> 18 </span></h2><hr/> +<span class='h_name'>rdkafka.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_7')"> +<span class='ext'>[+]</span> <span class='ttype'>enum</span> rd_kafka_resp_err_t <span class='passed'> 18 </span></span> +<br/> +<div id="c_7" style="display:none;"> +<table class='ptable'><tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th></tr><tr> +<th>1</th> +<td>The member <b>RD_KAFKA_RESP_ERR_CONCURRENT_TRANSACTIONS</b> with value <b>51</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>2</th> +<td>The member <b>RD_KAFKA_RESP_ERR_DUPLICATE_SEQUENCE_NUMBER</b> with value <b>46</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>3</th> +<td>The member <b>RD_KAFKA_RESP_ERR_INVALID_PRODUCER_EPOCH</b> with value <b>47</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>4</th> +<td>The member <b>RD_KAFKA_RESP_ERR_INVALID_PRODUCER_ID_MAPPING</b> with value <b>49</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>5</th> +<td>The member <b>RD_KAFKA_RESP_ERR_INVALID_TRANSACTION_TIMEOUT</b> with value <b>50</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>6</th> +<td>The member <b>RD_KAFKA_RESP_ERR_INVALID_TXN_STATE</b> with value <b>48</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>7</th> +<td>The member <b>RD_KAFKA_RESP_ERR_OPERATION_NOT_ATTEMPTED</b> with value <b>55</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>8</th> +<td>The member <b>RD_KAFKA_RESP_ERR_OUT_OF_ORDER_SEQUENCE_NUMBER</b> with value <b>45</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>9</th> +<td>The member <b>RD_KAFKA_RESP_ERR_POLICY_VIOLATION</b> with value <b>44</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>10</th> +<td>The member <b>RD_KAFKA_RESP_ERR_SECURITY_DISABLED</b> with value <b>54</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>11</th> +<td>The member <b>RD_KAFKA_RESP_ERR_TRANSACTIONAL_ID_AUTHORIZATION_FAILED</b> with value <b>53</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>12</th> +<td>The member <b>RD_KAFKA_RESP_ERR_TRANSACTION_COORDINATOR_FENCED</b> with value <b>52</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>13</th> +<td>The member <b>RD_KAFKA_RESP_ERR__INTR</b> with value <b>-163</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>14</th> +<td>The member <b>RD_KAFKA_RESP_ERR__KEY_DESERIALIZATION</b> with value <b>-160</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>15</th> +<td>The member <b>RD_KAFKA_RESP_ERR__KEY_SERIALIZATION</b> with value <b>-162</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>16</th> +<td>The member <b>RD_KAFKA_RESP_ERR__VALUE_DESERIALIZATION</b> with value <b>-159</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>17</th> +<td>The member <b>RD_KAFKA_RESP_ERR__VALUE_SERIALIZATION</b> with value <b>-161</b> has been added.</td> +<td>No effect.</td> +</tr> +<tr> +<th>18</th> +<td>Value of member <b>RD_KAFKA_RESP_ERR_END_ALL</b> has been changed from <b>44</b> to <b>56</b>.</td> +<td>No effect.</td> +</tr> +</table> +<span class="sect_aff" onclick="javascript:showContent(this, 'c_8')"> +[+] affected symbols: 63 (45%)</span> +<div id="c_8" style="display:none;"> +<div class='affected'><span class='iname_a'>rd_kafka_assign <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>partitions</span></span> )</span></span><br/> +<div class='affect'>Field 'partitions.elems.err' in 2nd parameter 'partitions' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_assignment <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t** <span class='fp'>partitions</span></span> )</span></span><br/> +<div class='affect'>Field 'partitions.elems.err' in 2nd parameter 'partitions' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_commit <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>offsets</span></span>, <span>int <i>async</i></span> )</span></span><br/> +<div class='affect'>Field 'offsets.elems.err' in 2nd parameter 'offsets' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_commit_message <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_message_t const* <span class='fp'>rkmessage</span></span>, <span>int <i>async</i></span> )</span></span><br/> +<div class='affect'>Field 'rkmessage.err' in 2nd parameter 'rkmessage' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_commit_queue <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <i>offsets</i></span>, <span>rd_kafka_queue_t* <i>rkqu</i></span>, <span>void(*<span class='fp'>cb</span>)(rd_kafka_t*, enum rd_kafka_resp_err_t, rd_kafka_topic_partition_list_t*, void*)</span>, <span>void* <i>opaque</i></span> )</span></span><br/> +<div class='affect'>Field 'cb.p1' in 4th parameter 'cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_committed <span class='sym_p'><span>( rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t* <span class='fp'>partitions</span></span>, <span>int <i>timeout_ms</i></span> )</span></span><br/> +<div class='affect'>Field 'partitions.elems.err' in 2nd parameter 'partitions' (pointer) is of type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_consume_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>consume_cb</span>)(rd_kafka_message_t*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'consume_cb.p0.err' in 2nd parameter 'consume_cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_dr_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>dr_cb</span>)(rd_kafka_t*, void*, size_t, enum rd_kafka_resp_err_t, void*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'dr_cb.p3' in 2nd parameter 'dr_cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_dr_msg_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>dr_msg_cb</span>)(rd_kafka_t*, rd_kafka_message_t const*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'dr_msg_cb.p1.err' in 2nd parameter 'dr_msg_cb' has base type 'enum rd_kafka_resp_err_t'.</div> +<span class='iname_a'>rd_kafka_conf_set_offset_commit_cb <span class='sym_p'><span>( rd_kafka_conf_t* <i>conf</i></span>, <span>void(*<span class='fp'>offset_commit_cb</span>)(rd_kafka_t*, enum rd_kafka_resp_err_t, rd_kafka_topic_partition_list_t*, void*)</span> )</span></span><br/> +<div class='affect'>Field 'offset_commit_cb.p1' in 2nd parameter 'offset_commit_cb' has base type 'enum rd_kafka_resp_err_t'.</div> + <b>...</b> +<br/> +</div> +</div> +<br/><br/></div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Other_Source_Changes_In_Constants'></a> +<h2>Other Changes in Constants <span class='passed'> 1 </span></h2><hr/> +<span class='h_name'>rdkafka.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_9')"> +<span class='ext'>[+]</span> RD_KAFKA_EVENT_STATS</span> +<br/> +<div id="c_9" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The constant <b>RD_KAFKA_EVENT_STATS</b> with value <b>0x40</b> has been added.</td> +<td>No effect.</td> +</tr> +</table> +<br/> +</div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Headers'></a><h2>Header Files <span class='gray'> 1 </span></h2><hr/> +<div class='h_list'> +rdkafka.h<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Libs'></a><h2>Libraries <span class='gray'> 1 </span></h2><hr/> +<div class='lib_list'> +librdkafka.so.1<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<br/><br/><br/></div><hr/> +<div class='footer' align='right'><i>Generated by <a href='https://github.com/lvc/abi-compliance-checker'>ABI Compliance Checker</a> 2.0  </i> +</div> +<br/> + +</body></html> diff --git a/librdkafka.spec b/librdkafka.spec index 687efd6..4682766 100644 --- a/librdkafka.spec +++ b/librdkafka.spec @@ -7,13 +7,13 @@ # Please, preserve the changelog entries # %global libname librdkafka -%global gh_commit e223a193cbc089714110e42ca9051f3f1ebc0695 +%global gh_commit ee261f8b867ae722f31b97e4e62be4b2767e8541 %global gh_short %(c=%{gh_commit}; echo ${c:0:7}) %global gh_owner edenhill %global gh_project %{libname} %global upstream_version 0.11.0 -%global upstream_prever RC1 +%global upstream_prever RC2 Name: %{libname} Version: %{upstream_version}%{?upstream_prever:~%{upstream_prever}} @@ -26,8 +26,6 @@ License: BSD and MIT URL: https://github.com/%{gh_owner}/%{gh_project} Source0: https://github.com/%{gh_owner}/%{gh_project}/archive/%{gh_commit}/%{gh_project}-%{upstream_version}%{?upstream_prever}-%{gh_short}.tar.gz -Patch0: a85c798f91bfef796116f3ebf5e5e7e479c8683f.patch - BuildRequires: openssl-devel BuildRequires: cyrus-sasl-devel BuildRequires: zlib-devel @@ -59,7 +57,6 @@ developing applications that use %{name}. %prep %setup -qn %{gh_project}-%{gh_commit} # no backup to avoid old version inclusion -%patch0 -p1 mkdir rpmdocs cp -pr examples rpmdocs/examples @@ -101,6 +98,9 @@ rm %{buildroot}%{_libdir}/*.a %changelog +* Thu Jun 29 2017 Remi Collet <remi@remirepo.net> - 0.11.0-RC2-1 +- update to 0.11.0-RC2 + * Thu Jun 29 2017 Remi Collet <remi@remirepo.net> - 0.11.0-RC1-1 - update to 0.11.0-RC1 - open https://github.com/edenhill/librdkafka/issues/1290 |