1311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff// Copyright 2008 Google Inc.
2311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff// Author: Lincoln Smith
3311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff//
4311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff// Licensed under the Apache License, Version 2.0 (the "License");
5311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff// you may not use this file except in compliance with the License.
6311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff// You may obtain a copy of the License at
7311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff//
8311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff//      http://www.apache.org/licenses/LICENSE-2.0
9311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff//
10311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff// Unless required by applicable law or agreed to in writing, software
11311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff// distributed under the License is distributed on an "AS IS" BASIS,
12311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff// See the License for the specific language governing permissions and
14311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff// limitations under the License.
15311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff
16311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff#ifndef OPEN_VCDIFF_LOGGING_H_
17311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff#define OPEN_VCDIFF_LOGGING_H_
18311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff
19311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff#include <config.h>
20732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com#include <stdlib.h>  // exit
21311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff#include <iostream>
22311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff
23311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiffnamespace open_vcdiff {
24311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff
25311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiffextern bool g_fatal_error_occurred;
26311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff
27311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiffinline void CheckFatalError() {
28311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff  if (g_fatal_error_occurred) {
29732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com    std::cerr.flush();
30732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com    exit(1);
31311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff  }
32311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff}
33311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff
34311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff}  // namespace open_vcdiff
35311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff
36732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com#define VCD_WARNING std::cerr << "WARNING: "
37732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com#define VCD_ERROR std::cerr << "ERROR: "
38732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com#ifndef NDEBUG
39732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com#define VCD_DFATAL open_vcdiff::g_fatal_error_occurred = true; \
40732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com                   std::cerr << "FATAL: "
41732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com#else  // NDEBUG
42732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com#define VCD_DFATAL VCD_ERROR
43732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com#endif  // !NDEBUG
44732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com
45732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com#define VCD_ENDL std::endl; \
46732fff248e662ec47aa27c124632f406f27b6c8dopenvcdiff@gmail.com                 open_vcdiff::CheckFatalError();
47311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff
48311c71486f5f6074e5ba62a7f4c5397c8700b868openvcdiff#endif  // OPEN_VCDIFF_LOGGING_H_
49