diff --git a/preprocessor/ModFile.cc b/preprocessor/ModFile.cc index 8f52e4775548924fcc3e58299c0327af999dd7b2..7bd8eb1c792642dfea507cdbddfdf6f4f1b89c07 100644 --- a/preprocessor/ModFile.cc +++ b/preprocessor/ModFile.cc @@ -296,6 +296,33 @@ ModFile::writeOutputFiles(const string &basename, bool clear_all if (!use_dll) mOutputFile << "erase_compiled_function('" + basename + "_dynamic');" << endl; +#if defined(_WIN32) || defined(__CYGWIN32__) + // If using USE_DLL with MSVC, check that the user didn't use a function not supported by MSVC (because MSVC doesn't comply with C99 standard) + if (use_dll && msvc) + { + if (dynamic_model.isUnaryOpUsed(oAcosh)) + { + cerr << "ERROR: acosh() function is not supported with USE_DLL option and MSVC compiler; use Cygwin compiler instead." << endl; + exit(EXIT_FAILURE); + } + if (dynamic_model.isUnaryOpUsed(oAsinh)) + { + cerr << "ERROR: asinh() function is not supported with USE_DLL option and MSVC compiler; use Cygwin compiler instead." << endl; + exit(EXIT_FAILURE); + } + if (dynamic_model.isUnaryOpUsed(oAtanh)) + { + cerr << "ERROR: atanh() function is not supported with USE_DLL option and MSVC compiler; use Cygwin compiler instead." << endl; + exit(EXIT_FAILURE); + } + if (dynamic_model.isTrinaryOpUsed(oNormcdf)) + { + cerr << "ERROR: normcdf() function is not supported with USE_DLL option and MSVC compiler; use Cygwin compiler instead." << endl; + exit(EXIT_FAILURE); + } + } +#endif + // Compile the dynamic MEX file for use_dll option if (use_dll) {