/usr/include/igraph/igraph_statusbar.h is in libigraph0-dev 0.7.1-2.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 | /* -*- mode: C -*- */
/*
IGraph library.
Copyright (C) 2010-2012 Gabor Csardi <csardi.gabor@gmail.com>
334 Harvard street, Cambridge, MA 02139 USA
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA
*/
#ifndef IGRAPH_STATUSBAR
#define IGRAPH_STATUSBAR
#undef __BEGIN_DECLS
#undef __END_DECLS
#ifdef __cplusplus
# define __BEGIN_DECLS extern "C" {
# define __END_DECLS }
#else
# define __BEGIN_DECLS /* empty */
# define __END_DECLS /* empty */
#endif
__BEGIN_DECLS
/**
* \section about_status_handlers Status reporting
*
* <para>
* In addition to the possibility of reporting the progress of an
* igraph computation via \ref igraph_progress(), it is also possible
* to report simple status messages from within igraph functions,
* without having to judge how much of the computation was performed
* already. For this one needs to install a status handler function.
* </para>
*
* <para>
* Status handler functions must be of type \ref igraph_status_handler_t
* and they can be install by a call to \ref igraph_set_status_handler().
* Currently there is a simple predefined status handler function,
* called \ref igraph_status_handler_stderr(), but the user can define
* new ones.
* </para>
*
* <para>
* Igraph functions report their status via a call to the
* \ref IGRAPH_STATUS() or the \ref IGRAPH_STATUSF() macro.
* </para>
*/
/**
* \typedef igraph_status_handler_t
*
* The type of the igraph status handler functions
* \param message The status message.
* \param data Additional context, with user-defined semantics.
* Existing igraph functions pass a null pointer here.
*/
typedef int igraph_status_handler_t(const char *message, void *data);
extern igraph_status_handler_t igraph_status_handler_stderr;
igraph_status_handler_t *
igraph_set_status_handler(igraph_status_handler_t new_handler);
int igraph_status(const char *message, void *data);
/**
* \define IGRAPH_STATUS
* Report the status of an igraph function.
*
* Typically this function is called only a handful of times from
* an igraph function. E.g. if an algorithm has three major
* steps, then it is logical to call it three times, to
* signal the three major steps.
* \param message The status message.
* \param data Additional context, with user-defined semantics.
* Existing igraph functions pass a null pointer here.
* \return If the status handler returns with a value other than
* \c IGRAPH_SUCCESS, then the function that called this
* macro returns as well, with error code
* \c IGRAPH_INTERRUPTED.
*/
#define IGRAPH_STATUS(message, data) \
do { \
if (igraph_status((message), (data)) != IGRAPH_SUCCESS) { \
IGRAPH_FINALLY_FREE(); \
return IGRAPH_INTERRUPTED; \
} \
} while (0)
int igraph_statusf(const char *message, void *data, ...);
/**
* \define IGRAPH_STATUSF
* Report the status from an igraph function
*
* This is the more flexible version of \ref IGRAPH_STATUS(),
* having a printf-like syntax. As this macro takes variable
* number of arguments, they must be all supplied as a single
* argument, enclosed in parentheses. Then \ref igraph_statusf()
* is called with the given arguments.
* \param args The arguments to pass to \ref igraph_statusf().
* \return If the status handler returns with a value other than
* \c IGRAPH_SUCCESS, then the function that called this
* macro returns as well, with error code
* \c IGRAPH_INTERRUPTED.
*/
#define IGRAPH_STATUSF(args) \
do { \
if (igraph_statusf args != IGRAPH_SUCCESS) { \
IGRAPH_FINALLY_FREE(); \
return IGRAPH_INTERRUPTED; \
} \
} while (0)
__END_DECLS
#endif
|