From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 107850 invoked by alias); 1 Nov 2018 15:58:20 -0000 Mailing-List: contact gcc-patches-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Id: List-Archive: List-Post: List-Help: Sender: gcc-patches-owner@gcc.gnu.org Received: (qmail 107741 invoked by uid 89); 1 Nov 2018 15:58:19 -0000 Authentication-Results: sourceware.org; auth=none X-Spam-SWARE-Status: No, score=-26.0 required=5.0 tests=AWL,BAYES_00,GIT_PATCH_0,GIT_PATCH_1,GIT_PATCH_2,GIT_PATCH_3,KAM_LOTSOFHASH,SPF_PASS autolearn=ham version=3.3.2 spammy= X-HELO: us-smtp-delivery-1.mimecast.com Received: from us-smtp-1.mimecast.com (HELO us-smtp-delivery-1.mimecast.com) (207.211.31.81) by sourceware.org (qpsmtpd/0.93/v0.84-503-g423c35a) with ESMTP; Thu, 01 Nov 2018 15:58:16 +0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=mathworks.com; s=mimecast20180117; t=1541087894; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=3Q/ATBrvX/FQvIwMszfAoRNdma7lsRDQW3fAyvxwvJY=; b=ITeHMdDec/8grEhrFt2c53IP8J3fmqYuPHnTmXIAHFz+SIM7Ayr26v+5C7XyaD+UWxiwNMAWn3FfvV5OXSTya5FoQK5uOOfD0wGCBcOtvTVQ+WCNV+r7q08OjIx5ujFPgEgKxx0w6pM4JeXYGTXssk75lkEI/SFiG/ZLZasqbtw= Received: from NAM02-BL2-obe.outbound.protection.outlook.com (mail-bl2nam02lp0086.outbound.protection.outlook.com [207.46.163.86]) (Using TLS) by dkim.mimecast.com with ESMTP id us-mta-81-Q_GPFJVsNPeXPfyEBpaNVw-1; Thu, 01 Nov 2018 11:58:10 -0400 Received: from SN4PR0501CA0013.namprd05.prod.outlook.com (2603:10b6:803:40::26) by CY1PR0501MB1115.namprd05.prod.outlook.com (2a01:111:e400:4c0f::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.1294.21; Thu, 1 Nov 2018 15:58:08 +0000 Received: from DM3NAM05FT031.eop-nam05.prod.protection.outlook.com (2a01:111:f400:7e51::209) by SN4PR0501CA0013.outlook.office365.com (2603:10b6:803:40::26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.20.1294.14 via Frontend Transport; Thu, 1 Nov 2018 15:58:08 +0000 Received: from exedge.mathworks.com (144.212.100.42) by DM3NAM05FT031.mail.protection.outlook.com (10.152.98.143) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.20.1318.5 via Frontend Transport; Thu, 1 Nov 2018 15:58:08 +0000 Received: from ex16-01-ah.mathworks.com (172.31.80.219) by ex16edge-00-ah.mathworks.com (172.31.187.33) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1466.3; Thu, 1 Nov 2018 11:57:02 -0400 Received: from ex16-00-ah.mathworks.com (172.31.39.22) by ex16-01-ah.mathworks.com (172.31.80.219) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1466.3; Thu, 1 Nov 2018 11:57:45 -0400 Received: from mail-vif.mathworks.com (144.212.95.101) by ex16-00-ah.mathworks.com (172.31.39.22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1466.3 via Frontend Transport; Thu, 1 Nov 2018 11:57:45 -0400 Received: from mgulick-deb9-64.dhcp.mathworks.com (mgulick-deb9-64.dhcp.mathworks.com [172.21.82.68]) by mail-vif.mathworks.com (8.14.7/8.14.7) with ESMTP id wA1FvjPp015423; Thu, 1 Nov 2018 11:57:45 -0400 Received: (from mgulick@localhost) by mgulick-deb9-64.dhcp.mathworks.com (8.15.2/8.15.2/Submit) id wA1FvjAC019388; Thu, 1 Nov 2018 11:57:45 -0400 From: Mike Gulick To: CC: David Malcolm , Mike Gulick Subject: [PATCH v3 3/3] PR preprocessor/83173: Enhance -fdump-internal-locations output Date: Thu, 01 Nov 2018 15:58:00 -0000 Message-ID: <20181101155607.11388-4-mgulick@mathworks.com> In-Reply-To: <20181101155607.11388-1-mgulick@mathworks.com> References: <7d281f10-a4e0-d81e-c405-d77ceda86f5b@mathworks.com> <20181101155607.11388-1-mgulick@mathworks.com> MIME-Version: 1.0 Return-Path: Mike.Gulick@mathworks.com Content-Type: text/plain; charset=WINDOWS-1252 Content-Transfer-Encoding: quoted-printable X-SW-Source: 2018-11/txt/msg00028.txt.bz2 2017-10-31 Mike Gulick PR preprocessor/83173 * gcc/input.c (dump_location_info): Dump reason and included_from fields from line_map_ordinary struct. Fix indentation when location > 5 digits. * libcpp/location-example.txt: Update example -fdump-internal-locations output. --- gcc/input.c | 49 +++++- libcpp/location-example.txt | 333 +++++++++++++++++++++--------------- 2 files changed, 241 insertions(+), 141 deletions(-) diff --git a/gcc/input.c b/gcc/input.c index a94a010f353..f938a37f20e 100644 --- a/gcc/input.c +++ b/gcc/input.c @@ -1075,6 +1075,17 @@ dump_labelled_location_range (FILE *stream, fprintf (stream, "\n"); } =20 +#define NUM_DIGITS(x) ((x) >=3D 1000000000 ? 10 : \ + (x) >=3D 100000000 ? 9 : \ + (x) >=3D 10000000 ? 8 : \ + (x) >=3D 1000000 ? 7 : \ + (x) >=3D 100000 ? 6 : \ + (x) >=3D 10000 ? 5 : \ + (x) >=3D 1000 ? 4 : \ + (x) >=3D 100 ? 3 : \ + (x) >=3D 10 ? 2 : \ + 1) + /* Write a visualization of the locations in the line_table to STREAM. */ =20 void @@ -1104,6 +1115,35 @@ dump_location_info (FILE *stream) map->m_column_and_range_bits - map->m_range_bits); fprintf (stream, " range bits: %i\n", map->m_range_bits); + const char * reason; + switch (map->reason) { + case LC_ENTER: + reason =3D "LC_ENTER"; + break; + case LC_LEAVE: + reason =3D "LC_LEAVE"; + break; + case LC_RENAME: + reason =3D "LC_RENAME"; + break; + case LC_RENAME_VERBATIM: + reason =3D "LC_RENAME_VERBATIM"; + break; + case LC_ENTER_MACRO: + reason =3D "LC_RENAME_MACRO"; + break; + default: + reason =3D "Unknown"; + } + fprintf (stream, " reason: %d (%s)\n", map->reason, reason); + + const line_map_ordinary *includer_map + =3D linemap_included_from_linemap (line_table, map); + fprintf (stream, " included from map: %d\n", + includer_map ? int (includer_map - line_table->info_ordinary.maps) + : -1); + fprintf (stream, " included from location: %d\n", + linemap_included_from (map)); =20 /* Render the span of source lines that this "map" covers. */ for (source_location loc =3D MAP_START_LOCATION (map); @@ -1137,7 +1177,14 @@ dump_location_info (FILE *stream) if (max_col > line_text.length ()) max_col =3D line_text.length () + 1; =20 - int indent =3D 14 + strlen (exploc.file); + int len_lnum =3D NUM_DIGITS (exploc.line); + if (len_lnum < 3) + len_lnum =3D 3; + int len_loc =3D NUM_DIGITS (loc); + if (len_loc < 5) + len_loc =3D 5; + + int indent =3D 6 + strlen (exploc.file) + len_lnum + len_loc; =20 /* Thousands. */ if (end_location > 999) diff --git a/libcpp/location-example.txt b/libcpp/location-example.txt index 14b5c2e284a..dc448b0493e 100644 --- a/libcpp/location-example.txt +++ b/libcpp/location-example.txt @@ -33,8 +33,12 @@ ORDINARY MAP: 0 source_location interval: 32 <=3D loc < 64 file: test.c starting at line: 1 - column bits: 12 + column and range bits: 12 + column bits: 7 range bits: 5 + reason: 0 (LC_ENTER) + included from map: -1 + included from location: 0 test.c: 1|loc: 32|#include "test.h" |69269258258148147 |46802468024680246 @@ -43,186 +47,235 @@ ORDINARY MAP: 1 source_location interval: 64 <=3D loc < 96 file: starting at line: 0 + column and range bits: 0 column bits: 0 range bits: 0 + reason: 2 (LC_RENAME) + included from map: -1 + included from location: 0 =20 ORDINARY MAP: 2 source_location interval: 96 <=3D loc < 128 file: starting at line: 0 + column and range bits: 0 column bits: 0 range bits: 0 + reason: 2 (LC_RENAME) + included from map: -1 + included from location: 0 =20 ORDINARY MAP: 3 - source_location interval: 128 <=3D loc < 160128 + source_location interval: 128 <=3D loc < 250240 file: /usr/include/stdc-predef.h starting at line: 1 - column bits: 12 + column and range bits: 12 + column bits: 7 range bits: 5 + reason: 0 (LC_ENTER) + included from map: 2 + included from location: 127 (contents of /usr/include/stdc-predef.h snipped for brevity) =20 ORDINARY MAP: 4 - source_location interval: 160128 <=3D loc < 160160 + source_location interval: 250240 <=3D loc < 250272 file: starting at line: 32 - column bits: 12 + column and range bits: 12 + column bits: 7 range bits: 5 + reason: 1 (LC_LEAVE) + included from map: -1 + included from location: 0 =20 ORDINARY MAP: 5 - source_location interval: 160160 <=3D loc < 164256 + source_location interval: 250272 <=3D loc < 254368 file: test.c starting at line: 1 - column bits: 12 + column and range bits: 12 + column bits: 7 range bits: 5 -test.c: 1|loc:160160|#include "test.h" - |00000000000000000 - |12223334445556667 - |92582581481470470 - |24680246802468024 + reason: 2 (LC_RENAME) + included from map: -1 + included from location: 0 +test.c: 1|loc:250272|#include "test.h" + |00000000000000000 + |33344445556667778 + |03603692692582581 + |46802468024680246 =20 ORDINARY MAP: 6 - source_location interval: 164256 <=3D loc < 173280 + source_location interval: 254368 <=3D loc < 266720 file: test.h starting at line: 1 - column bits: 12 + column and range bits: 12 + column bits: 7 range bits: 5 -test.h: 1|loc:164256|extern int foo (); - |444444444444444444 - |233344455566677788 - |825814814704703603 - |802468024680246802 -test.h: 2|loc:168352| - | - | - | - | -test.h: 3|loc:172448|#define PLUS(A, B) A + B - |222222222222222223333333 - |455566677788889990001112 - |814704703603692692582581 - |024680246802468024680246 + reason: 0 (LC_ENTER) + included from map: 5 + included from location: 250272 +test.h: 1|loc:254368|extern int foo (); + |444444444444444444 + |444455566677788899 + |036926925825814814 + |024680246802468024 +test.h: 2|loc:258464| + | + | + | + | +test.h: 3|loc:262560|#define PLUS(A, B) A + B + |222222222222233333333333 + |566677788899900011122223 + |925825814814704703603692 + |246802468024680246802468 +test.h: 4|loc:266656| + | + | + | + | =20 ORDINARY MAP: 7 - source_location interval: 173280 <=3D loc < 202016 + source_location interval: 266720 <=3D loc < 299520 file: test.c starting at line: 2 - column bits: 12 + column and range bits: 12 + column bits: 7 range bits: 5 -test.c: 2|loc:173280| - | - | - | - | -test.c: 3|loc:177376|int - |777 - |444 - |047 - |802 -test.c: 4|loc:181472|main (int argc, char **argv) - |1111111111111111222222222222 - |5556666777888999000111222333 - |0360369269258258148147047036 - |4680246802468024680246802468 -test.c: 5|loc:185568|{ - |5 - |6 - |0 - |0 -test.c: 6|loc:189664| int a =3D PLUS (1,2); - |999999999900000000000 - |677788899900011122233 - |926925825814814704703 - |680246802468024680246 -test.c: 7|loc:193760| int b =3D PLUS (3,4); - |333333344444444444444 - |788899900011122233344 - |925825814814704703603 - |246802468024680246802 -test.c: 8|loc:197856| return 0; - |77778888888 - |89990001112 - |82581481470 - |80246802468 -test.c: 9|loc:201952|} - |1 - |9 - |8 - |4 + reason: 1 (LC_LEAVE) + included from map: -1 + included from location: 0 +test.c: 2|loc:266720| + | + | + | + | +test.c: 3|loc:270816|int + |000 + |889 + |481 + |802 +test.c: 4|loc:274912|main (int argc, char **argv) + |4455555555555555555555555555 + |9900011122223334445556667778 + |4704703603692692582581481470 + |4680246802468024680246802468 +test.c: 5|loc:279008|{ + |9 + |0 + |4 + |0 +test.c: 6|loc:283104| int a =3D PLUS (1,2); + |333333333333333333333 + |112222333444555666777 + |360369269258258148147 + |680246802468024680246 +test.c: 7|loc:287200| int b =3D PLUS (3,4); + |777777777777777777777 + |222333444555666777888 + |369269258258148147047 + |246802468024680246802 +test.c: 8|loc:291296| return 0; + |11111111111 + |33344455566 + |26925825814 + |80246802468 +test.c: 9|loc:295392|} + |5 + |4 + |2 + |4 +test.c: 10|loc:299488| + | + | + | + | =20 UNALLOCATED LOCATIONS - source_location interval: 202016 <=3D loc < 2147483633 + source_location interval: 299520 <=3D loc < 2147483632 =20 -MACRO 1: PLUS (7 tokens) - source_location interval: 2147483633 <=3D loc < 2147483640 -test.c:7:11: note: expansion point is location 194115 - int b =3D PLUS (3,4); - ^~~~ +MACRO 3: PLUS (7 tokens) + source_location interval: 2147483632 <=3D loc < 2147483639 +test.c:7:11: note: expansion point is location 287555 + 7 | int b =3D PLUS (3,4); + | ^~~~ + map->start_location: 2147483632 + macro_locations: + 0: 287744, 263200 +test.c:7:17: note: token 0 has x-location =3D=3D 287744 + 7 | int b =3D PLUS (3,4); + | ^ +test.c:7:17: note: token 0 has y-location =3D=3D 263200 + 1: 263264, 263264 +In file included from test.c:1: +test.h:3:22: note: token 1 has x-location =3D=3D y-location =3D=3D 263264 + 3 | #define PLUS(A, B) A + B + | ^ + 2: 287808, 263328 +test.c:7:19: note: token 2 has x-location =3D=3D 287808 + 7 | int b =3D PLUS (3,4); + | ^ +test.c:7:19: note: token 2 has y-location =3D=3D 263328 + 3: 0, 0 +cc1: note: token 3 has x-location =3D=3D y-location =3D=3D 0 + 4: 0, 0 +cc1: note: token 4 has x-location =3D=3D y-location =3D=3D 0 + 5: 0, 0 +cc1: note: token 5 has x-location =3D=3D y-location =3D=3D 0 + 6: 0, 0 +cc1: note: token 6 has x-location =3D=3D y-location =3D=3D 0 + +MACRO 2: PLUS (7 tokens) + source_location interval: 2147483639 <=3D loc < 2147483646 +test.c:6:11: note: expansion point is location 283459 + 6 | int a =3D PLUS (1,2); + | ^~~~ + map->start_location: 2147483639 + macro_locations: + 0: 283648, 263200 +test.c:6:17: note: token 0 has x-location =3D=3D 283648 + 6 | int a =3D PLUS (1,2); + | ^ +test.c:6:17: note: token 0 has y-location =3D=3D 263200 + 1: 263264, 263264 +In file included from test.c:1: +test.h:3:22: note: token 1 has x-location =3D=3D y-location =3D=3D 263264 + 3 | #define PLUS(A, B) A + B + | ^ + 2: 283712, 263328 +test.c:6:19: note: token 2 has x-location =3D=3D 283712 + 6 | int a =3D PLUS (1,2); + | ^ +test.c:6:19: note: token 2 has y-location =3D=3D 263328 + 3: 0, 0 +cc1: note: token 3 has x-location =3D=3D y-location =3D=3D 0 + 4: 0, 0 +cc1: note: token 4 has x-location =3D=3D y-location =3D=3D 0 + 5: 0, 0 +cc1: note: token 5 has x-location =3D=3D y-location =3D=3D 0 + 6: 0, 0 +cc1: note: token 6 has x-location =3D=3D y-location =3D=3D 0 =20 - map->start_location: 2147483633 +MACRO 1: __GCC_IEC_559_COMPLEX (1 tokens) + source_location interval: 2147483646 <=3D loc < 2147483647 +In file included from :31: +/usr/include/stdc-predef.h:45:6: note: expansion point is location 180564 + 45 | # if __GCC_IEC_559_COMPLEX > 0 + | ^~~~~~~~~~~~~~~~~~~~~ + map->start_location: 2147483646 macro_locations: - 0: 194304, 173088 -test.c:7:17: note: token 0 has x-location =3D=3D 194304 - int b =3D PLUS (3,4); - ^ - -test.c:7:17: note: token 0 has y-location =3D=3D 173088 - 1: 173152, 173152 -In file included from test.c:1:0: -test.h:3:22: note: token 1 has x-location =3D=3D y-location =3D=3D 173152 - #define PLUS(A, B) A + B - ^ - - 2: 194368, 173216 -test.c:7:19: note: token 2 has x-location =3D=3D 194368 - int b =3D PLUS (3,4); - ^ - -test.c:7:19: note: token 2 has y-location =3D=3D 173216 - 3: 0, 2947526575 -cc1: note: token 3 has x-location =3D=3D 0 -cc1: note: token 3 has y-location =3D=3D 2947526575 - 4: 2947526575, 2947526575 -x-location =3D=3D y-location =3D=3D 2947526575 encodes token # 800042942 - 5: 2947526575, 2947526575 -x-location =3D=3D y-location =3D=3D 2947526575 encodes token # 800042942 - 6: 2947526575, 2947526575 -x-location =3D=3D y-location =3D=3D 2947526575 encodes token # 800042942 - -MACRO 0: PLUS (7 tokens) - source_location interval: 2147483640 <=3D loc < 2147483647 -test.c:6:11: note: expansion point is location 190019 - int a =3D PLUS (1,2); - ^~~~ - - map->start_location: 2147483640 + 0: 1, 1 +: note: token 0 has x-location =3D=3D y-location =3D=3D 1 + +MACRO 0: __GCC_IEC_559 (1 tokens) + source_location interval: 2147483647 <=3D loc < 2147483648 +/usr/include/stdc-predef.h:37:6: note: expansion point is location 147788 + 37 | # if __GCC_IEC_559 > 0 + | ^~~~~~~~~~~~~ + map->start_location: 2147483647 macro_locations: - 0: 190208, 173088 -test.c:6:17: note: token 0 has x-location =3D=3D 190208 - int a =3D PLUS (1,2); - ^ - -test.c:6:17: note: token 0 has y-location =3D=3D 173088 - 1: 173152, 173152 -In file included from test.c:1:0: -test.h:3:22: note: token 1 has x-location =3D=3D y-location =3D=3D 173152 - #define PLUS(A, B) A + B - ^ - - 2: 190272, 173216 -test.c:6:19: note: token 2 has x-location =3D=3D 190272 - int a =3D PLUS (1,2); - ^ - -test.c:6:19: note: token 2 has y-location =3D=3D 173216 - 3: 0, 2947526575 -cc1: note: token 3 has x-location =3D=3D 0 -cc1: note: token 3 has y-location =3D=3D 2947526575 - 4: 2947526575, 2947526575 -x-location =3D=3D y-location =3D=3D 2947526575 encodes token # 800042935 - 5: 2947526575, 2947526575 -x-location =3D=3D y-location =3D=3D 2947526575 encodes token # 800042935 - 6: 2947526575, 2947526575 -x-location =3D=3D y-location =3D=3D 2947526575 encodes token # 800042935 + 0: 1, 1 +: note: token 0 has x-location =3D=3D y-location =3D=3D 1 =20 MAX_SOURCE_LOCATION source_location interval: 2147483647 <=3D loc < 2147483648 --=20 2.19.1