kopia lustrzana https://github.com/Hamlib/Hamlib
flexible debug reporting
git-svn-id: https://hamlib.svn.sourceforge.net/svnroot/hamlib/trunk@1997 7ae35d74-ebe9-4afe-98af-79ac388436b8Hamlib-1.2.5
rodzic
8a03048c98
commit
f79eaeccda
|
@ -2,7 +2,7 @@
|
|||
* Hamlib Interface - API header
|
||||
* Copyright (c) 2000-2005 by Stephane Fillod and Frank Singleton
|
||||
*
|
||||
* $Id: rig.h,v 1.106 2005-04-03 22:33:08 fillods Exp $
|
||||
* $Id: rig.h,v 1.107 2005-04-06 21:27:27 fillods Exp $
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Library General Public License as
|
||||
|
@ -23,6 +23,9 @@
|
|||
#ifndef _RIG_H
|
||||
#define _RIG_H 1
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdarg.h>
|
||||
|
||||
#include <hamlib/riglist.h> /* list in another file to not mess up w/ this one */
|
||||
|
||||
/*! \file rig.h
|
||||
|
@ -1331,6 +1334,8 @@ struct rig_state {
|
|||
};
|
||||
|
||||
|
||||
typedef int (*vprintf_cb_t) (enum rig_debug_level_e, rig_ptr_t, const char *, va_list);
|
||||
|
||||
typedef int (*freq_cb_t) (RIG *, vfo_t, freq_t, rig_ptr_t);
|
||||
typedef int (*mode_cb_t) (RIG *, vfo_t, rmode_t, pbwidth_t, rig_ptr_t);
|
||||
typedef int (*vfo_cb_t) (RIG *, vfo_t, rig_ptr_t);
|
||||
|
@ -1544,8 +1549,11 @@ extern HAMLIB_EXPORT(int) rig_setting2idx HAMLIB_PARAMS((setting_t s));
|
|||
* Maybe "hamlib_" would have been better. Let me know. --SF
|
||||
*/
|
||||
extern HAMLIB_EXPORT(void) rig_set_debug HAMLIB_PARAMS((enum rig_debug_level_e debug_level));
|
||||
#define rig_set_debug_level(level) rig_set_debug(level)
|
||||
extern HAMLIB_EXPORT(int) rig_need_debug HAMLIB_PARAMS((enum rig_debug_level_e debug_level));
|
||||
extern HAMLIB_EXPORT(void) rig_debug HAMLIB_PARAMS((enum rig_debug_level_e debug_level, const char *fmt, ...));
|
||||
extern HAMLIB_EXPORT(vprintf_cb_t) rig_set_debug_callback HAMLIB_PARAMS((vprintf_cb_t cb, rig_ptr_t arg));
|
||||
extern HAMLIB_EXPORT(FILE*) rig_set_debug_file HAMLIB_PARAMS((FILE *stream));
|
||||
|
||||
extern HAMLIB_EXPORT(int) rig_register HAMLIB_PARAMS((const struct rig_caps *caps));
|
||||
extern HAMLIB_EXPORT(int) rig_unregister HAMLIB_PARAMS((rig_model_t rig_model));
|
||||
|
|
73
src/misc.c
73
src/misc.c
|
@ -2,7 +2,7 @@
|
|||
* Hamlib Interface - toolbox
|
||||
* Copyright (c) 2000-2005 by Stephane Fillod
|
||||
*
|
||||
* $Id: misc.c,v 1.36 2005-04-04 21:24:51 fillods Exp $
|
||||
* $Id: misc.c,v 1.37 2005-04-06 21:27:28 fillods Exp $
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Library General Public License as
|
||||
|
@ -41,6 +41,9 @@
|
|||
|
||||
|
||||
static int rig_debug_level = RIG_DEBUG_TRACE;
|
||||
static FILE *rig_debug_stream;
|
||||
static vprintf_cb_t rig_vprintf_cb;
|
||||
static rig_ptr_t rig_vprintf_arg;
|
||||
|
||||
/*
|
||||
* Do a hex dump of the unsigned char array.
|
||||
|
@ -200,7 +203,7 @@ unsigned long long HAMLIB_API from_bcd_be(const unsigned char bcd_data[], unsign
|
|||
*/
|
||||
void HAMLIB_API rig_set_debug(enum rig_debug_level_e debug_level)
|
||||
{
|
||||
rig_debug_level = debug_level;
|
||||
rig_debug_level = debug_level;
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -214,23 +217,71 @@ int HAMLIB_API rig_need_debug(enum rig_debug_level_e debug_level)
|
|||
|
||||
/*
|
||||
* rig_debug
|
||||
* Debugging messages are done through stderr
|
||||
* TODO: add syslog support if needed
|
||||
* Default is debugging messages are done through stderr
|
||||
*/
|
||||
void HAMLIB_API rig_debug(enum rig_debug_level_e debug_level, const char *fmt, ...)
|
||||
{
|
||||
va_list ap;
|
||||
|
||||
if (debug_level <= rig_debug_level) {
|
||||
va_start(ap, fmt);
|
||||
/*
|
||||
* Who cares about return code?
|
||||
*/
|
||||
vfprintf (stderr, fmt, ap);
|
||||
va_end(ap);
|
||||
if (!rig_need_debug(debug_level))
|
||||
return;
|
||||
|
||||
|
||||
va_start(ap, fmt);
|
||||
|
||||
if (rig_vprintf_cb) {
|
||||
|
||||
rig_vprintf_cb(debug_level, rig_vprintf_arg, fmt, ap);
|
||||
|
||||
} else {
|
||||
if (!rig_debug_stream)
|
||||
rig_debug_stream = stderr;
|
||||
|
||||
vfprintf (rig_debug_stream, fmt, ap);
|
||||
}
|
||||
|
||||
va_end(ap);
|
||||
}
|
||||
|
||||
/**
|
||||
* \brief set callback to handle debug messages
|
||||
* \param cb The callback to install
|
||||
* \param arg A Pointer to some private data to pass later on to the callback
|
||||
*
|
||||
* Install a callback for \a rig_debug messages.
|
||||
*
|
||||
* \return RIG_OK if the operation has been sucessful, otherwise
|
||||
* a negative value if an error occured (in which case, cause
|
||||
* is set appropriately).
|
||||
*
|
||||
* \sa rig_debug()
|
||||
*/
|
||||
//typedef int (*vprintf_cb_t) (enum rig_debug_level_e debug_level, rig_ptr_t, const char *, va_list);
|
||||
vprintf_cb_t rig_set_debug_callback(vprintf_cb_t cb, rig_ptr_t arg)
|
||||
{
|
||||
vprintf_cb_t prev_cb = rig_vprintf_cb;
|
||||
|
||||
rig_vprintf_cb = cb;
|
||||
rig_vprintf_arg = arg;
|
||||
|
||||
return prev_cb;
|
||||
}
|
||||
|
||||
/**
|
||||
* \brief change stderr to some different output
|
||||
* \param stream The stream to set output to
|
||||
*/
|
||||
FILE *rig_set_debug_file(FILE *stream)
|
||||
{
|
||||
FILE *prev_stream = rig_debug_stream;
|
||||
|
||||
rig_debug_stream = stream;
|
||||
|
||||
return prev_stream;
|
||||
}
|
||||
|
||||
|
||||
|
||||
#ifndef llabs
|
||||
#define llabs(a) ((a)<0?-(a):(a))
|
||||
#endif
|
||||
|
|
Ładowanie…
Reference in New Issue