JUCE-7.0.12-0-g4f43011b96 JUCE-7.0.12-0-g4f43011b96
JUCE — C++ application framework with suport for VST, VST3, LV2 audio plug-ins

« « « Anklang Documentation
Loading...
Searching...
No Matches
juce_Logger.cpp
Go to the documentation of this file.
1 /*
2 ==============================================================================
3
4 This file is part of the JUCE library.
5 Copyright (c) 2022 - Raw Material Software Limited
6
7 JUCE is an open source library subject to commercial or open-source
8 licensing.
9
10 The code included in this file is provided under the terms of the ISC license
11 http://www.isc.org/downloads/software-support-policy/isc-license. Permission
12 To use, copy, modify, and/or distribute this software for any purpose with or
13 without fee is hereby granted provided that the above copyright notice and
14 this permission notice appear in all copies.
15
16 JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
17 EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
18 DISCLAIMED.
19
20 ==============================================================================
21*/
22
23namespace juce
24{
25
26Logger::Logger() {}
27
29{
30 // You're deleting this logger while it's still being used!
31 // Always call Logger::setCurrentLogger (nullptr) before deleting the active logger.
32 jassert (currentLogger != this);
33}
34
35Logger* Logger::currentLogger = nullptr;
36
37void Logger::setCurrentLogger (Logger* const newLogger) noexcept { currentLogger = newLogger; }
38Logger* Logger::getCurrentLogger() noexcept { return currentLogger; }
39
40void Logger::writeToLog (const String& message)
41{
42 if (currentLogger != nullptr)
43 currentLogger->logMessage (message);
44 else
45 outputDebugString (message);
46}
47
48#if JUCE_LOG_ASSERTIONS || JUCE_DEBUG
49void JUCE_API JUCE_CALLTYPE logAssertion (const char* const filename, const int lineNum) noexcept
50{
51 String m ("JUCE Assertion failure in ");
53
54 #if JUCE_LOG_ASSERTIONS
56 #else
57 DBG (m);
58 #endif
59}
60#endif
61
62} // namespace juce
Wraps a pointer to a null-terminated UTF-8 character string, and provides various methods to operate ...
String getFileName() const
Returns the last section of the pathname.
static File createFileWithoutCheckingPath(const String &absolutePath) noexcept
Creates a file that simply contains this string, without doing the sanity-checking that the normal co...
Definition juce_File.cpp:31
Acts as an application-wide logging class.
Definition juce_Logger.h:41
virtual void logMessage(const String &message)=0
This is overloaded by subclasses to implement custom logging behaviour.
virtual ~Logger()
Destructor.
static void JUCE_CALLTYPE writeToLog(const String &message)
Writes a string to the current logger.
static void JUCE_CALLTYPE setCurrentLogger(Logger *newLogger) noexcept
Sets the current logging class to use.
static void JUCE_CALLTYPE outputDebugString(const String &text)
Writes a message to the standard error stream.
static Logger *JUCE_CALLTYPE getCurrentLogger() noexcept
Returns the current logger, or nullptr if no custom logger has been set.
The JUCE String class!
Definition juce_String.h:53
#define jassert(expression)
Platform-independent assertion macro.
#define DBG(textToWrite)
Writes a string to the standard error stream.
#define JUCE_CALLTYPE
This macro defines the C calling convention used as the standard for JUCE calls.
JUCE Namespace.
void logAssertion(const char *file, int line) noexcept
< This macro is added to all JUCE public class declarations.
Type unalignedPointerCast(void *ptr) noexcept
Casts a pointer to another type via void*, which suppresses the cast-align warning which sometimes ar...
Definition juce_Memory.h:88