X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=ginac%2Fexcompiler.cpp;h=a2698db07ea8c27bae9e4966b822c9efc1f93aa1;hp=375776d8e1428595f1ce4a8d42c9ac9f8f8d6e7e;hb=f49f9a14764515fd7c2ddc20d7c7cb651ba25cc0;hpb=95ede03f00106be5fb087d76c86ca5c27edb9122 diff --git a/ginac/excompiler.cpp b/ginac/excompiler.cpp index 375776d8..a2698db0 100644 --- a/ginac/excompiler.cpp +++ b/ginac/excompiler.cpp @@ -6,7 +6,7 @@ */ /* - * GiNaC Copyright (C) 1999-2010 Johannes Gutenberg University Mainz, Germany + * GiNaC Copyright (C) 1999-2018 Johannes Gutenberg University Mainz, Germany * * 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 @@ -36,8 +36,16 @@ #include "symbol.h" #ifdef HAVE_LIBDL -#include +# include #endif // def HAVE_LIBDL +#ifdef HAVE_UNISTD_H +# include +#else +# ifdef _MSC_VER +# include // for close(3) +# endif // def _MSC_VER +#endif // def HAVE_UNISTD_H +#include #include #include #include @@ -48,7 +56,7 @@ namespace GiNaC { #ifdef HAVE_LIBDL - + /** * Small class that manages modules opened by libdl. It is used by compile_ex * and link_ex in order to have a clean-up of opened modules and their @@ -72,11 +80,11 @@ class excompiler std::vector filelist; /**< List of all opened modules */ public: /** - * Complete clean-up of opend modules is done on destruction. + * Complete clean-up of opened modules is done on destruction. */ ~excompiler() { - for (std::vector::const_iterator it = filelist.begin(); it != filelist.end(); ++it) { + for (auto it = filelist.begin(); it != filelist.end(); ++it) { clean_up(it); } } @@ -112,13 +120,15 @@ public: const char* filename_pattern = "./GiNaCXXXXXX"; char* new_filename = new char[strlen(filename_pattern)+1]; strcpy(new_filename, filename_pattern); - if (!mktemp(new_filename)) { - delete new_filename; - throw std::runtime_error("mktemp failed"); + int fd = mkstemp(new_filename); + if (fd == -1) { + delete[] new_filename; + throw std::runtime_error("mkstemp failed"); } filename = std::string(new_filename); ofs.open(new_filename, std::ios::out); - delete new_filename; + close(fd); + delete[] new_filename; } else { // use parameter as filename ofs.open(filename.c_str(), std::ios::out); @@ -140,7 +150,7 @@ public: */ void compile_src_file(const std::string filename, bool clean_up) { - std::string strcompile = "ginac-excompiler " + filename; + std::string strcompile = LIBEXECDIR "ginac-excompiler " + filename; if (system(strcompile.c_str())) { throw std::runtime_error("excompiler::compile_src_file: error compiling source file!"); } @@ -153,9 +163,9 @@ public: */ void* link_so_file(const std::string filename, bool clean_up) { - void* module = NULL; + void* module = nullptr; module = dlopen(filename.c_str(), RTLD_NOW); - if (module == NULL) { + if (module == nullptr) { throw std::runtime_error("excompiler::link_so_file: could not open compiled module!"); } @@ -169,10 +179,10 @@ public: */ void unlink(const std::string filename) { - for (std::vector::iterator it = filelist.begin(); it != filelist.end();) { + for (auto it = filelist.begin(); it != filelist.end();) { if (it->name == filename) { clean_up(it); - filelist.erase(it); + it = filelist.erase(it); } else { ++it; } @@ -181,7 +191,7 @@ public: }; /** - * This static object manages the modules opened by the complile_ex and link_ex + * This static object manages the modules opened by the compile_ex and link_ex * functions. On program termination its dtor is called and all open modules * are closed. The associated source and so-files are eventually deleted then * as well. @@ -195,7 +205,7 @@ static excompiler global_excompiler; void compile_ex(const ex& expr, const symbol& sym, FUNCP_1P& fp, const std::string filename) { symbol x("x"); - ex expr_with_x = expr.subs(lst(sym==x)); + ex expr_with_x = expr.subs(lst{sym==x}); std::ofstream ofs; std::string unique_filename = filename; @@ -220,7 +230,7 @@ void compile_ex(const ex& expr, const symbol& sym, FUNCP_1P& fp, const std::stri void compile_ex(const ex& expr, const symbol& sym1, const symbol& sym2, FUNCP_2P& fp, const std::string filename) { symbol x("x"), y("y"); - ex expr_with_xy = expr.subs(lst(sym1==x, sym2==y)); + ex expr_with_xy = expr.subs(lst{sym1==x, sym2==y}); std::ofstream ofs; std::string unique_filename = filename;