Summary: Adapted a stderr logger from the option tests. Moved it to a separate header so we can reuse it, e.g., from ldb subcommands for faster debugging. This is especially useful to make errors/warnings more visible when running "ldb repair", which involves potential data loss. Test Plan: ran options_test and "ldb repair" $ ./ldb repair --db=./tmp/ [WARN] **** Repaired rocksdb ./tmp/; recovered 1 files; 588bytes. Some data may have been lost. **** OK Reviewers: IslamAbdelRahman, yhchiang, sdong Reviewed By: sdong Subscribers: andrewkr, dhruba, leveldb Differential Revision: https://reviews.facebook.net/D56151main
parent
b55e2165be
commit
f2c43a4a27
@ -0,0 +1,31 @@ |
|||||||
|
// Copyright (c) 2016-present, Facebook, Inc. All rights reserved.
|
||||||
|
// This source code is licensed under the BSD-style license found in the
|
||||||
|
// LICENSE file in the root directory of this source tree. An additional grant
|
||||||
|
// of patent rights can be found in the PATENTS file in the same directory.
|
||||||
|
|
||||||
|
#pragma once |
||||||
|
|
||||||
|
#include <stdarg.h> |
||||||
|
#include <stdio.h> |
||||||
|
|
||||||
|
#include "rocksdb/env.h" |
||||||
|
|
||||||
|
namespace rocksdb { |
||||||
|
|
||||||
|
// Prints logs to stderr for faster debugging
|
||||||
|
class StderrLogger : public Logger { |
||||||
|
public: |
||||||
|
explicit StderrLogger(const InfoLogLevel log_level = InfoLogLevel::INFO_LEVEL) |
||||||
|
: Logger(log_level) {} |
||||||
|
|
||||||
|
// Brings overloaded Logv()s into scope so they're not hidden when we override
|
||||||
|
// a subset of them.
|
||||||
|
using Logger::Logv; |
||||||
|
|
||||||
|
virtual void Logv(const char* format, va_list ap) override { |
||||||
|
vfprintf(stderr, format, ap); |
||||||
|
fprintf(stderr, "\n"); |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
} // namespace rocksdb
|
Loading…
Reference in new issue