Summary: Moves the `YGLogger` into `YGConfig` and pass the `YGNodeRef` into the logger to be able to associate the log messages and assertions with the specific node. Tackles facebook/yoga#530 and facebook/yoga#446 Closes https://github.com/facebook/yoga/pull/531 Reviewed By: astreet Differential Revision: D4970149 Pulled By: emilsjolander fbshipit-source-id: b7fcdaa273143ea2fa35861620b2e4d79f04f0af
32 lines
966 B
C++
32 lines
966 B
C++
/**
|
|
* Copyright (c) 2014-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.
|
|
*/
|
|
|
|
#include "YGInterop.h"
|
|
|
|
static YGInteropLogger gManagedLogger;
|
|
|
|
static int unmanagedLogger(const YGConfigRef config,
|
|
const YGNodeRef node,
|
|
YGLogLevel level,
|
|
const char *format,
|
|
va_list args) {
|
|
int result = 0;
|
|
if (gManagedLogger) {
|
|
char message[8192];
|
|
result = vsnprintf(message, sizeof(message), format, args);
|
|
(*gManagedLogger)(config, node, level, message);
|
|
}
|
|
return result;
|
|
}
|
|
|
|
void YGInteropSetLogger(YGInteropLogger managedLogger) {
|
|
gManagedLogger = managedLogger;
|
|
YGSetLogger(YGConfigGetDefault(), &unmanagedLogger);
|
|
}
|