CMake: Add option to link against system-wide Gflags library
[blender.git] / intern / libmv / intern / logging.cc
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * The Original Code is Copyright (C) 2011 Blender Foundation.
19  * All rights reserved.
20  *
21  * Contributor(s): Blender Foundation,
22  *                 Sergey Sharybin
23  *
24  * ***** END GPL LICENSE BLOCK *****
25  */
26
27 #include "intern/logging.h"
28 #include "intern/utildefines.h"
29 #include "libmv/logging/logging.h"
30
31 void libmv_initLogging(const char* argv0) {
32   using LIBMV_GFLAGS_NAMESPACE::SetCommandLineOption;
33   // Make it so FATAL messages are always print into console.
34   char severity_fatal[32];
35   snprintf(severity_fatal, sizeof(severity_fatal), "%d",
36            google::GLOG_FATAL);
37   google::InitGoogleLogging(argv0);
38   SetCommandLineOption("logtostderr", "1");
39   SetCommandLineOption("v", "0");
40   SetCommandLineOption("stderrthreshold", severity_fatal);
41   SetCommandLineOption("minloglevel", severity_fatal);
42 }
43
44 void libmv_startDebugLogging(void) {
45   using LIBMV_GFLAGS_NAMESPACE::SetCommandLineOption;
46   SetCommandLineOption("logtostderr", "1");
47   SetCommandLineOption("v", "2");
48   SetCommandLineOption("stderrthreshold", "1");
49   SetCommandLineOption("minloglevel", "0");
50 }
51
52 void libmv_setLoggingVerbosity(int verbosity) {
53   using LIBMV_GFLAGS_NAMESPACE::SetCommandLineOption;
54   char val[10];
55   snprintf(val, sizeof(val), "%d", verbosity);
56   SetCommandLineOption("v", val);
57 }