Skip to content

Commit

Permalink
Display entity and location with Block_Logger traces as additional info
Browse files Browse the repository at this point in the history
The source location and the enclosing entity are always displayed by
GNATCOLL.Traces.Block_Logger, as part of the message:

```
 [PKG] Entering Foo:pkg.adb:5
```

Obtaining the same piece of information with a GNATCOLL.Traces.Trace_Handle
can be achieved with the DEBUG.ENTITY_ENCLOSING and DEBUG.LOCATION
in a .gnatdebug configuration file:

```
[PKG] ... (loc: main.adb:12)(entity:Main.Foo)
```

To avoid duplication, this information was not displayed for
Block_Logger traces, but an empty field was still present:

```
[PKG] Entering Main.Foo:main.adb:10 (loc:)(entity:)
```

To keep the logs consistent, the location and entity enclosing information
so are also displayed in the (loc:) and (entity:) fields if the
debug configuration variables ENCLOSING_ENTITY and LOCATION are set.
  • Loading branch information
Jicquel committed May 21, 2024
1 parent 89bdf16 commit ee6f217
Show file tree
Hide file tree
Showing 11 changed files with 128 additions and 11 deletions.
36 changes: 26 additions & 10 deletions src/gnatcoll-traces.adb
Original file line number Diff line number Diff line change
Expand Up @@ -1278,7 +1278,7 @@ package body GNATCOLL.Traces is
end if;

if Global.Location.Active then
Msg.Append ("(loc: ");
Msg.Append ("(loc:");
Msg.Append (Location);
Msg.Append (')');
end if;
Expand Down Expand Up @@ -2178,15 +2178,23 @@ package body GNATCOLL.Traces is
if Active (Handle) then
Result.Me := Handle;
Result.Style := Style;
Result.Loc := new String'(Entity & ':' & Location);
Result.Location := new String'(Location);
Result.Entity := new String'(Entity);

-- To ensure consistency between all traces, location and entity
-- are also displayed in the loc and entity fields of the message,
-- despite this piece of information already being contained in
-- the first part of the message.

if Message /= "" then
Increase_Indent
(Handle, "Entering " & Result.Loc.all & ' ' & Message,
Style => Style, Location => "", Entity => "");
(Handle,
"Entering " & Entity & ':' & Location & ' ' & Message,
Style => Style, Location => Location, Entity => Entity);
else
Increase_Indent
(Handle, "Entering " & Result.Loc.all,
Style => Style, Location => "", Entity => "");
(Handle, "Entering " & Entity & ':' & Location,
Style => Style, Location => Location, Entity => Entity);
end if;
end if;
end return;
Expand All @@ -2200,13 +2208,21 @@ package body GNATCOLL.Traces is
begin
-- If we were active when Create was called
if Self.Me /= null then

-- To ensure consistency between all traces, location and entity
-- are also displayed in the loc and entity fields of the message,
-- despite this piece of information already being contained in
-- the first part of the message.

Decrease_Indent
(Self.Me, "Leaving " & Self.Loc.all,
(Self.Me, "Leaving " & Self.Entity.all & ':' & Self.Location.all,
Style => Self.Style,
Location => "", -- avoid duplicate info in the output
Entity => "");
Location => Self.Location.all,
Entity => Self.Entity.all);
end if;
Free (Self.Loc);

Free (Self.Location);
Free (Self.Entity);
end Finalize;

end GNATCOLL.Traces;
3 changes: 2 additions & 1 deletion src/gnatcoll-traces.ads
Original file line number Diff line number Diff line change
Expand Up @@ -900,7 +900,8 @@ private
type Block_Trace_Handle is new Ada.Finalization.Limited_Controlled with
record
Me : Logger;
Loc : GNAT.Strings.String_Access;
Location : GNAT.Strings.String_Access;
Entity : GNAT.Strings.String_Access;
Style : Message_Style;
end record;
overriding procedure Finalize (Self : in out Block_Logger);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
PKG=yes
DEBUG.ENCLOSING_ENTITY=no
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
PKG=yes
DEBUG.ENCLOSING_ENTITY=yes
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
PKG=yes
DEBUG.LOCATION=no
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
PKG=yes
DEBUG.LOCATION=yes
24 changes: 24 additions & 0 deletions testsuite/tests/traces/debug_config_parsing/test.adb
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
with GNATCOLL.Traces; use GNATCOLL.Traces;
with Ada.Command_Line;

procedure Test is

Log : constant Logger := Create ("PKG");

procedure Foo (A : Integer);
-- Recursive function that decrement A and that traces its value
-- until it reaches 1 (included).

procedure Foo (A : Integer) is
Block_Log : constant Block_Logger := Create (Log);
begin
Trace (Log, "A =" & A'Img);
if A > 1 then
Foo (A - 1);
end if;
end Foo;

begin
Parse_Config_File (Ada.Command_Line.Argument (1));
Foo (3);
end Test;
7 changes: 7 additions & 0 deletions testsuite/tests/traces/debug_config_parsing/test.gpr
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
with "gnatcoll";

project Test is
for Object_Dir use "obj";
for Exec_Dir use ".";
for Main use ("test.adb");
end Test;
43 changes: 43 additions & 0 deletions testsuite/tests/traces/debug_config_parsing/test.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
== DEBUG.LOCATION=yes
[PKG] Entering Test.Foo:test.adb:13 (loc:test.adb:13)
[PKG] A = 3 (loc:test.adb:15)
[PKG] Entering Test.Foo:test.adb:13 (loc:test.adb:13)
[PKG] A = 2 (loc:test.adb:15)
[PKG] Entering Test.Foo:test.adb:13 (loc:test.adb:13)
[PKG] A = 1 (loc:test.adb:15)
[PKG] Leaving Test.Foo:test.adb:13 (loc:test.adb:13)
[PKG] Leaving Test.Foo:test.adb:13 (loc:test.adb:13)
[PKG] Leaving Test.Foo:test.adb:13 (loc:test.adb:13)

== DEBUG.LOCATION=no
[PKG] Entering Test.Foo:test.adb:13
[PKG] A = 3
[PKG] Entering Test.Foo:test.adb:13
[PKG] A = 2
[PKG] Entering Test.Foo:test.adb:13
[PKG] A = 1
[PKG] Leaving Test.Foo:test.adb:13
[PKG] Leaving Test.Foo:test.adb:13
[PKG] Leaving Test.Foo:test.adb:13

== DEBUG.ENCLOSING_ENTITY=yes
[PKG] Entering Test.Foo:test.adb:13 (entity:Test.Foo)
[PKG] A = 3 (entity:Test.Foo)
[PKG] Entering Test.Foo:test.adb:13 (entity:Test.Foo)
[PKG] A = 2 (entity:Test.Foo)
[PKG] Entering Test.Foo:test.adb:13 (entity:Test.Foo)
[PKG] A = 1 (entity:Test.Foo)
[PKG] Leaving Test.Foo:test.adb:13 (entity:Test.Foo)
[PKG] Leaving Test.Foo:test.adb:13 (entity:Test.Foo)
[PKG] Leaving Test.Foo:test.adb:13 (entity:Test.Foo)

== DEBUG.ENCLOSING_ENTITY=no
[PKG] Entering Test.Foo:test.adb:13
[PKG] A = 3
[PKG] Entering Test.Foo:test.adb:13
[PKG] A = 2
[PKG] Entering Test.Foo:test.adb:13
[PKG] A = 1
[PKG] Leaving Test.Foo:test.adb:13
[PKG] Leaving Test.Foo:test.adb:13
[PKG] Leaving Test.Foo:test.adb:13
14 changes: 14 additions & 0 deletions testsuite/tests/traces/debug_config_parsing/test.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
echo "== DEBUG.LOCATION=yes"
./test .gnatdebug_location_yes

echo ""
echo "== DEBUG.LOCATION=no"
./test .gnatdebug_location_no

echo ""
echo "== DEBUG.ENCLOSING_ENTITY=yes"
./test .gnatdebug_enclosing_entity_yes

echo ""
echo "== DEBUG.ENCLOSING_ENTITY=no"
./test .gnatdebug_enclosing_entity_no
4 changes: 4 additions & 0 deletions testsuite/tests/traces/debug_config_parsing/test.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
driver: build_run_diff
description: Check behavior of DEBUG configuration variants
control:
- [SKIP, "env.is_cross", "Tests using test.sh currently not supported on cross targets, see T616-039"]

0 comments on commit ee6f217

Please sign in to comment.