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