view examples/myprop.c @ 18205:8c92b5e7fa4d

improve handling of integer field overflow in printf (bug #36278) * oct-stream.cc (DO_DOUBLE_CONV_1): If value will overflow given format type, switch to G format. (DO_DOUBLE_CONV): Check format modifier and call DO_DOUBLE_CONV_1 to do the real work. (octave_base_stream::do_print): Style fix.
author John W. Eaton <jwe@octave.org>
date Fri, 03 Jan 2014 15:12:30 -0500
parents 224e76250443
children
line wrap: on
line source

#include "mex.h"

void
mexFunction (int nlhs, mxArray* plhs[],
             int nrhs, const mxArray* prhs[])
{
  double handle;
  char property[256];

  if (nrhs < 2 || nrhs > 3)
    mexErrMsgTxt ("incorrect number of arguments");
  if (!mxIsDouble (prhs[0]))
    mexErrMsgTxt ("handle expected to be a double scalar");
  if (!mxIsChar (prhs[1]))
    mexErrMsgTxt ("expected property to be a string");

  handle = mxGetScalar (prhs[0]);
  mxGetString (prhs[1], property, 256);
  plhs[0] = mxDuplicateArray (mexGet (handle, property));

  if (nrhs == 3)
    if (mexSet (handle, property, mxDuplicateArray (prhs[2])))
      mexErrMsgTxt ("failed to set property");
}