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
|
//------------------------------------------------------------------------------
// gbburble: get/set the burble setting for diagnostic output
//------------------------------------------------------------------------------
// SuiteSparse:GraphBLAS, Timothy A. Davis, (c) 2017-2022, All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0
//------------------------------------------------------------------------------
// Usage
// b = gbburble ;
// b = gbburble (b) ;
#include "gb_interface.h"
#define USAGE "usage: b = GrB.burble ; or GrB.burble (b)"
void mexFunction
(
int nargout,
mxArray *pargout [ ],
int nargin,
const mxArray *pargin [ ]
)
{
//--------------------------------------------------------------------------
// check inputs
//--------------------------------------------------------------------------
gb_usage (nargin <= 1 && nargout <= 1, USAGE) ;
//--------------------------------------------------------------------------
// set the burble, if requested
//--------------------------------------------------------------------------
bool b ;
if (nargin > 0)
{
// set the burble
if (gb_mxarray_is_scalar (pargin [0]))
{
// argument is a numeric scalar
b = (bool) mxGetScalar (pargin [0]) ;
}
else if (mxIsLogicalScalar (pargin [0]))
{
// argument is a logical scalar
b = (bool) mxIsLogicalScalarTrue (pargin [0]) ;
}
else
{
ERROR ("input must be a scalar") ;
}
OK (GxB_Global_Option_set (GxB_BURBLE, b)) ;
}
//--------------------------------------------------------------------------
// return the burble
//--------------------------------------------------------------------------
OK (GxB_Global_Option_get (GxB_BURBLE, &b)) ;
pargout [0] = mxCreateDoubleScalar (b) ;
GB_WRAPUP ;
}
|