1 /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* vim: set ts=8 sts=2 et sw=2 tw=80: */
3 /* This Source Code Form is subject to the terms of the Mozilla Public
4 * License, v. 2.0. If a copy of the MPL was not distributed with this
5 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
7 #ifndef mozilla_StaticAnalysisFunctions_h
8 #define mozilla_StaticAnalysisFunctions_h
16 #define MOZ_CONSTEXPR constexpr
19 * Functions that are used as markers in Gecko code for static analysis. Their
20 * purpose is to have different AST nodes generated during compile time and to
21 * match them based on different checkers implemented in build/clang-plugin
24 #ifdef MOZ_CLANG_PLUGIN
28 * MOZ_KnownLive - used to opt an argument out of the CanRunScript checker so
29 * that we don't check it if is a strong ref.
32 * canRunScript(MOZ_KnownLive(rawPointer));
35 static MOZ_ALWAYS_INLINE T
* MOZ_KnownLive(T
* ptr
) { return ptr
; }
38 * Ditto, but for references.
41 static MOZ_ALWAYS_INLINE T
& MOZ_KnownLive(T
& ref
) { return ref
; }
46 * MOZ_AssertAssignmentTest - used in MOZ_ASSERT in order to test the possible
47 * presence of assignment instead of logical comparisons.
50 * MOZ_ASSERT(retVal = true);
52 static MOZ_ALWAYS_INLINE MOZ_CONSTEXPR
bool MOZ_AssertAssignmentTest(bool exprResult
) {
56 #define MOZ_CHECK_ASSERT_ASSIGNMENT(expr) MOZ_AssertAssignmentTest(!!(expr))
60 #define MOZ_CHECK_ASSERT_ASSIGNMENT(expr) (!!(expr))
61 #define MOZ_KnownLive(expr) (expr)
63 #endif /* MOZ_CLANG_PLUGIN */
64 #endif /* StaticAnalysisFunctions_h */