0N/A/*
2362N/A * Copyright (c) 2003, 2004, Oracle and/or its affiliates. All rights reserved.
0N/A *
0N/A * Redistribution and use in source and binary forms, with or without
0N/A * modification, are permitted provided that the following conditions
0N/A * are met:
0N/A *
0N/A * - Redistributions of source code must retain the above copyright
0N/A * notice, this list of conditions and the following disclaimer.
0N/A *
0N/A * - Redistributions in binary form must reproduce the above copyright
0N/A * notice, this list of conditions and the following disclaimer in the
0N/A * documentation and/or other materials provided with the distribution.
0N/A *
2362N/A * - Neither the name of Oracle nor the names of its
0N/A * contributors may be used to endorse or promote products derived
0N/A * from this software without specific prior written permission.
0N/A *
0N/A * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
0N/A * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
0N/A * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
0N/A * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
0N/A * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
0N/A * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
0N/A * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
0N/A * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
0N/A * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
0N/A * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
0N/A * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
0N/A */
0N/A
4378N/A/*
4378N/A * This source code is provided to illustrate the usage of a given feature
4378N/A * or technique and has been deliberately simplified. Additional steps
4378N/A * required for a production-quality application, such as security checks,
4378N/A * input validation and proper error handling, might not be present in
4378N/A * this sample code.
4378N/A */
4378N/A
4378N/A
0N/A#ifndef HPROF_ERROR_H
0N/A#define HPROF_ERROR_H
0N/A
0N/A/* Macros over assert and error functions so we can capture the source loc. */
0N/A
0N/A#define HPROF_BOOL(x) ((jboolean)((x)==0?JNI_FALSE:JNI_TRUE))
0N/A
0N/A#define HPROF_ERROR(fatal,msg) \
0N/A error_handler(HPROF_BOOL(fatal), JVMTI_ERROR_NONE, msg, __FILE__, __LINE__)
0N/A
0N/A#define HPROF_JVMTI_ERROR(error,msg) \
0N/A error_handler(HPROF_BOOL(error!=JVMTI_ERROR_NONE), \
0N/A error, msg, __FILE__, __LINE__)
0N/A
0N/A#if defined(DEBUG) || !defined(NDEBUG)
0N/A #define HPROF_ASSERT(cond) \
0N/A (((int)(cond))?(void)0:error_assert(#cond, __FILE__, __LINE__))
0N/A#else
0N/A #define HPROF_ASSERT(cond)
0N/A#endif
0N/A
0N/A#define LOG_DUMP_MISC 0x1 /* Misc. logging info */
0N/A#define LOG_DUMP_LISTS 0x2 /* Dump tables at vm init and death */
0N/A#define LOG_CHECK_BINARY 0x4 /* If format=b, verify binary format */
0N/A
0N/A#ifdef HPROF_LOGGING
0N/A #define LOG_STDERR(args) \
0N/A { \
0N/A if ( gdata != NULL && (gdata->logflags & LOG_DUMP_MISC) ) { \
0N/A (void)fprintf args ; \
0N/A } \
0N/A }
0N/A#else
0N/A #define LOG_STDERR(args)
0N/A#endif
0N/A
0N/A#define LOG_FORMAT(format) "HPROF LOG: " format " [%s:%d]\n"
0N/A
0N/A#define LOG1(str1) LOG_STDERR((stderr, LOG_FORMAT("%s"), \
0N/A str1, __FILE__, __LINE__ ))
0N/A#define LOG2(str1,str2) LOG_STDERR((stderr, LOG_FORMAT("%s %s"), \
0N/A str1, str2, __FILE__, __LINE__ ))
0N/A#define LOG3(str1,str2,num) LOG_STDERR((stderr, LOG_FORMAT("%s %s 0x%x"), \
0N/A str1, str2, num, __FILE__, __LINE__ ))
0N/A
0N/A#define LOG(str) LOG1(str)
0N/A
0N/Avoid error_handler(jboolean fatal, jvmtiError error,
0N/A const char *message, const char *file, int line);
0N/Avoid error_assert(const char *condition, const char *file, int line);
0N/Avoid error_exit_process(int exit_code);
0N/Avoid error_do_pause(void);
0N/Avoid error_setup(void);
0N/Avoid debug_message(const char * format, ...);
0N/Avoid verbose_message(const char * format, ...);
0N/A
0N/A#endif