aboutsummaryrefslogtreecommitdiff
path: root/pw_trace/trace_backend_compile_test_c.c
blob: 0001775cae83cb672b6b504fcc97b4cc18af9205 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
// Copyright 2020 The Pigweed Authors
//
// Licensed under the Apache License, Version 2.0 (the "License"); you may not
// use this file except in compliance with the License. You may obtain a copy of
// the License at
//
//     https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
// License for the specific language governing permissions and limitations under
// the License.
//
// This is a simple test that ensures a provided trace backend compiles.

#define PW_TRACE_MODULE_NAME "TST"

#include "pw_trace/trace.h"

#ifdef __cplusplus
#error "This file must be compiled as plain C to verify C compilation works."
#endif  // __cplusplus

void BasicTraceTestPlainC() {
  PW_TRACE_INSTANT("Test");

  PW_TRACE_START("Test");
  PW_TRACE_END("Test");

  PW_TRACE_START("Parent", "group");
  PW_TRACE_START("Child", "group");
  PW_TRACE_END("Child", "group");
  PW_TRACE_INSTANT("Test", "group");
  PW_TRACE_START("Other Child", "group");
  PW_TRACE_END("Other Child", "group");
  PW_TRACE_END("Parent", "group");

  PW_TRACE_START("label for start", "group", 1);
  PW_TRACE_INSTANT("label for step", "group", 1);
  PW_TRACE_END("label for end", "group", 1);

  const char kSomeData[] = "SOME DATA";
  PW_TRACE_INSTANT_DATA("Test", "s", kSomeData, sizeof(kSomeData));

  PW_TRACE_START_DATA("Parent", "group", "s", kSomeData, sizeof(kSomeData));
  PW_TRACE_START_DATA("Child", "group", "s", kSomeData, sizeof(kSomeData));
  PW_TRACE_END_DATA("child", "group", "s", kSomeData, sizeof(kSomeData));
  PW_TRACE_INSTANT_DATA("Test", "group", "s", kSomeData, sizeof(kSomeData));
  PW_TRACE_START_DATA(
      "Other Child", "group", "s", kSomeData, sizeof(kSomeData));
  PW_TRACE_END_DATA("Other Child", "group", "s", kSomeData, sizeof(kSomeData));
  PW_TRACE_END_DATA("Parent", "group", "s", kSomeData, sizeof(kSomeData));

  uint32_t trace_id = 1;
  PW_TRACE_START_DATA(
      "label for start", "group", trace_id, "s", kSomeData, sizeof(kSomeData));
  PW_TRACE_INSTANT_DATA(
      "label for step", "group", trace_id, "s", kSomeData, sizeof(kSomeData));
  PW_TRACE_END_DATA(
      "label for end", "group", trace_id, "s", kSomeData, sizeof(kSomeData));
}