From 272817b253ce59825aec57736f3554529db01ab2 Mon Sep 17 00:00:00 2001 From: Giuliano Procida Date: Wed, 5 Feb 2020 11:17:13 +0000 Subject: [PATCH] Fix stray comma in leaf-changes-only mode. This change replaces the "\n," sometimes seen in output (such as for the PR25128 test cases) with a correctly indented "and". * src/abg-reporter-priv.cc (represent): Don't try to follow output of indented pretty representation with a comma, just emit "and" unconditionally; remove unnecessary intermediate ostringstream. * tests/data/Makefile.am: Add new test case files. * tests/data/test-abidiff-exit/test-no-stray-comma-*: New test cases. * tests/data/test-diff-suppr/test46-PR25128-report-?.txt: Replace unindented comma with indented "and". * tests/test-abidiff-exit.cc: Add no-stray-comma test case. Signed-off-by: Giuliano Procida Reviewed-by: Matthias Maennich --- src/abg-reporter-priv.cc | 17 ++++++----------- tests/data/Makefile.am | 3 +++ .../test-no-stray-comma-report.txt | 14 ++++++++++++++ .../test-abidiff-exit/test-no-stray-comma-v0.o | Bin 0 -> 2784 bytes .../test-abidiff-exit/test-no-stray-comma-v1.o | Bin 0 -> 2784 bytes .../test46-PR25128-report-1.txt | 2 +- .../test46-PR25128-report-2.txt | 2 +- tests/test-abidiff-exit.cc | 9 +++++++++ 8 files changed, 34 insertions(+), 13 deletions(-) create mode 100644 tests/data/test-abidiff-exit/test-no-stray-comma-report.txt create mode 100644 tests/data/test-abidiff-exit/test-no-stray-comma-v0.o create mode 100644 tests/data/test-abidiff-exit/test-no-stray-comma-v1.o diff --git a/src/abg-reporter-priv.cc b/src/abg-reporter-priv.cc index f9e08c91..fff7b55b 100644 --- a/src/abg-reporter-priv.cc +++ b/src/abg-reporter-priv.cc @@ -486,30 +486,25 @@ represent(const var_diff_sptr &diff, { if (local_only && d->has_local_changes()) { - std::ostringstream out_buffer; - out_buffer - << indent << "type '" << get_pretty_representation(o->get_type()) + out << indent << "type '" << get_pretty_representation(o->get_type()) << "' of '" << o->get_qualified_name() << "' changed"; if (d->currently_reporting()) { - out_buffer << " as being reported\n"; - begin_with_and = true; + out << " as being reported\n"; } else if (d->reported_once()) { - out_buffer << " as reported earlier\n"; - begin_with_and = true; + out << " as reported earlier\n"; } else { - out_buffer << ":\n"; - d->report(out_buffer, indent + " "); - begin_with_and = false; + out << ":\n"; + d->report(out, indent + " "); } - out << out_buffer.str(); + begin_with_and = true; emitted = true; } else diff --git a/tests/data/Makefile.am b/tests/data/Makefile.am index 1f574d2e..a38fadfd 100644 --- a/tests/data/Makefile.am +++ b/tests/data/Makefile.am @@ -107,6 +107,9 @@ test-abidiff-exit/test-loc-v0.bi \ test-abidiff-exit/test-loc-v1.bi \ test-abidiff-exit/test-loc-with-locs-report.txt \ test-abidiff-exit/test-loc-without-locs-report.txt \ +test-abidiff-exit/test-no-stray-comma-report.txt \ +test-abidiff-exit/test-no-stray-comma-v0.o \ +test-abidiff-exit/test-no-stray-comma-v1.o \ \ test-diff-dwarf/test0-v0.cc \ test-diff-dwarf/test0-v0.o \ diff --git a/tests/data/test-abidiff-exit/test-no-stray-comma-report.txt b/tests/data/test-abidiff-exit/test-no-stray-comma-report.txt new file mode 100644 index 00000000..a66500d5 --- /dev/null +++ b/tests/data/test-abidiff-exit/test-no-stray-comma-report.txt @@ -0,0 +1,14 @@ +Leaf changes summary: 1 artifact changed +Changed leaf types summary: 1 leaf type changed +Removed/Changed/Added functions summary: 0 Removed, 0 Changed, 0 Added function +Removed/Changed/Added variables summary: 0 Removed, 0 Changed, 0 Added variable + +'struct foo at test-b146198490-v0.cc:1:1' changed: + type size changed from 32 to 64 (in bits) + there are data member changes: + type 'int[1]' of 'foo::bar' changed: + type name changed from 'int[1]' to 'int[2]' + array type size changed from 32 to 64 + array type subrange 1 changed length from 1 to 2 + and size changed from 32 to 64 (in bits) (by +32 bits) + diff --git a/tests/data/test-abidiff-exit/test-no-stray-comma-v0.o b/tests/data/test-abidiff-exit/test-no-stray-comma-v0.o new file mode 100644 index 0000000000000000000000000000000000000000..1d40e893d4727497e66062e2b2f66b9c291742e3 GIT binary patch literal 2784 zcmbtV&1(}u6n~RVnzY-7w6U5}g%$j$Xx5gNk}B0`{b;d@2n7+O?k3wb+H54*YE{I8 zB8ry^f{5Zl{|WD2{1f~KJbLgZc+mG|-=v#yMbLqr_ulV)&di&g2d5X$B!mDp1RR4c zNudB%&lX>nY#H(}1WWTzzsx_q|9$i7$F~S4r79yMguDd8$&B!cm1Yx?LS*Igv6PI|t3Z_g0 zVo>bO=1n6znjI8F>D&&~=7o_l%_HVfbH)^TtYrX9XvQOWtHqnd)z8Ef_2}Ut$DuJs#j2ST9wt=jnZ^+ zdde!+;Be5m3CmX|@vttPo1_DWvvYGttg%y`TX+00N^$x?$jAa=TS!3My#!(-Cr10z znN3{PPQ>Y>A@}4&HupF&H_&qi4MI3}rcFu0x1VuJTzec02A_nkG*A;a3~qZ}XFykj zcGL#QUhc?>F`!qmUDW9Gb{CA*40Ho58GtPrGYshe4aF;fw|HwGI{g;k0^O&HzG{Vi z5uTE$OoY>_#t6hQ7!pwU5X-|FewpPFrc`04bCEy5IK_#c|FsAn-OaX!hkq4-+l=e+ zqw7ks4Uya*?2rBdw-~3|qxFN`zS9UC7irK6>8j!aZzBM^>I4qhZo3V3%Ug5os^_lP zmh1jX6LpezT({-j>QXx`$FF(aE^Bq)Q!bbS>`JrI@bH$~elzfFyw$~a;8bpKAa8Yf zrR6j{F8n{qDEiahs{K^q%FJ~7jpeOQ41wK92-9!gIkwk{?!O-ms6YPIe*%5=n3PlH ze@8-O=(hAyA|i5SIH zbs{TAk}uu>>s@v%3tj()uZR8*q<1@$OY4Xon9l|pUy*&9Y4zRvAD{IPrU(>sLYT&42}fy{wmFhX){wO$9EF?|j}&9NK6 zV%=A{K|F^nQO4mWejPM0Na{)CpvMzc&xcOOz7H%BstG_wXK&x2VHfH9Ns7H#1B0gl z*2|8kGKQ8KO!cz9Wcmx>{u3SPGbm)4ri%S{4f?D`v;t zxT?d5(?`Vj}Hp!*LLuK?cSy?to)TXYk(pCdlGuR?S;V0;I{ z@x$v%2peMQeeBQegPQ`U*x~qKHSg7Y+d=L(0=_0C-`)1XD%-vdmeXv4)o|BstL!?P zm6fWuT1Oq1ZO3W2TWxB)VS5#~-DSP%xzYtwfK{s3YA)V#%d7jYg?ByI^zG6e5y)Lz zS#8)gR}}uAY!LnF?BssRa77`s`c2IDIxzr_A|p(_c~^wJ%2fZ8Xh8k(ul{-TRbx_4 zng2aaLZsT#f1Mt}V#tQXqIey@2%P$gAlb|KIB=T8QH@E8Z(IvNFI<>Z+eK8W7}-A) z;BeSE!j{$dq{B+;d{2Pc- zOj#$2oZ{j#-j;yiGQZ>x5RdZrg#VGh_&*W;iWxi?{wgl>O8m9(SIu_?P>_a#%k@k6 zB??jdcPnE5=+%(^a$l()H8;inEWkxkF#Xr*HB$ZQOw_xF5M-$+q+