From 820232eacaa88e81be044a90dcc3b96e411dea8c Mon Sep 17 00:00:00 2001 From: hakan-demirli Date: Wed, 31 Jan 2024 19:50:31 +0300 Subject: [PATCH] fix: function naming and locations --- kernel/driver.cc | 75 +----------------------------------------------- kernel/yosys.cc | 65 +++++++++++++++++++++++++++++++++++++++-- kernel/yosys.h | 4 +++ 3 files changed, 68 insertions(+), 76 deletions(-) diff --git a/kernel/driver.cc b/kernel/driver.cc index ee30c2b27..5f105ea03 100644 --- a/kernel/driver.cc +++ b/kernel/driver.cc @@ -53,78 +53,6 @@ # include #endif -#include // _stat -#include // errno, ENOENT, EEXIST -#if defined(_WIN32) -# include -# define mkdir(path, mode) _mkdir(path) -# define PATH_DELIMETER "\\" -#else -# define PATH_DELIMETER "/" -#endif - - - -bool isDirExist(const std::string& path) -{ -#if defined(_WIN32) - struct _stat info; - if (_stat(path.c_str(), &info) != 0) - { - return false; - } - return (info.st_mode & _S_IFDIR) != 0; -#else - struct stat info; - if (stat(path.c_str(), &info) != 0) - { - return false; - } - return (info.st_mode & S_IFDIR) != 0; -#endif -} -bool makePath(const std::string& path) -{ -#if defined(_WIN32) - int ret = _mkdir(path.c_str()); -#else - mode_t mode = 0755; - int ret = mkdir(path.c_str(), mode); -#endif - if (ret == 0) - return true; - - switch (errno) - { - case ENOENT: - // parent didn't exist, try to create it - { - int pos = path.find_last_of('/'); - if (pos == std::string::npos) -#if defined(_WIN32) - pos = path.find_last_of('\\'); - if (pos == std::string::npos) -#endif - return false; - if (!makePath( path.substr(0, pos) )) - return false; - } - // now, try to create again -#if defined(_WIN32) - return 0 == _mkdir(path.c_str()); -#else - return 0 == mkdir(path.c_str(), mode); -#endif - - case EEXIST: - // done! - return isDirExist(path); - - default: - return false; - } -} - USING_YOSYS_NAMESPACE char *optarg; @@ -329,8 +257,7 @@ int main(int argc, char **argv) if (!state_dir.empty()) { std::string yosys_dir = state_dir + "/yosys"; - // mkdir(yosys_dir.c_str(), 0777); - makePath(yosys_dir); + create_directory(yosys_dir); yosys_history_file = yosys_dir + "/history"; read_history(yosys_history_file.c_str()); diff --git a/kernel/yosys.cc b/kernel/yosys.cc index 4409dc91d..0362bc1eb 100644 --- a/kernel/yosys.cc +++ b/kernel/yosys.cc @@ -436,6 +436,25 @@ std::string make_temp_dir(std::string template_str) #endif } +bool check_dir_exists(const std::string& path) +{ +#if defined(_WIN32) + struct _stat info; + if (_stat(path.c_str(), &info) != 0) + { + return false; + } + return (info.st_mode & _S_IFDIR) != 0; +#else + struct stat info; + if (stat(path.c_str(), &info) != 0) + { + return false; + } + return (info.st_mode & S_IFDIR) != 0; +#endif +} + #ifdef _WIN32 bool check_file_exists(std::string filename, bool) { @@ -481,6 +500,48 @@ void remove_directory(std::string dirname) #endif } +bool create_directory(const std::string& path) +{ +#if defined(_WIN32) + int ret = _mkdir(path.c_str()); +#else + mode_t mode = 0755; + int ret = mkdir(path.c_str(), mode); +#endif + if (ret == 0) + return true; + + switch (errno) + { + case ENOENT: + // parent didn't exist, try to create it + { + std::string::size_type pos = path.find_last_of('/'); + if (pos == std::string::npos) +#if defined(_WIN32) + pos = path.find_last_of('\\'); + if (pos == std::string::npos) +#endif + return false; + if (!create_directory( path.substr(0, pos) )) + return false; + } + // now, try to create again +#if defined(_WIN32) + return 0 == _mkdir(path.c_str()); +#else + return 0 == mkdir(path.c_str(), mode); +#endif + + case EEXIST: + // done! + return check_dir_exists(path); + + default: + return false; + } +} + std::string escape_filename_spaces(const std::string& filename) { std::string out; @@ -781,10 +842,10 @@ static int tcl_yosys_cmd(ClientData, Tcl_Interp *interp, int argc, const char *a int yosys_tcl_iterp_init(Tcl_Interp *interp) { - if (Tcl_Init(interp)!=TCL_OK) + if (Tcl_Init(interp)!=TCL_OK) log_warning("Tcl_Init() call failed - %s\n",Tcl_ErrnoMsg(Tcl_GetErrno())); Tcl_CreateCommand(interp, "yosys", tcl_yosys_cmd, NULL, NULL); - return TCL_OK ; + return TCL_OK ; } void yosys_tcl_activate_repl() diff --git a/kernel/yosys.h b/kernel/yosys.h index 97a79861e..76ad01aa9 100644 --- a/kernel/yosys.h +++ b/kernel/yosys.h @@ -66,6 +66,8 @@ #include #include #include +#include +#include #ifdef WITH_PYTHON #include @@ -341,8 +343,10 @@ std::string get_base_tmpdir(); std::string make_temp_file(std::string template_str = get_base_tmpdir() + "/yosys_XXXXXX"); std::string make_temp_dir(std::string template_str = get_base_tmpdir() + "/yosys_XXXXXX"); bool check_file_exists(std::string filename, bool is_exec = false); +bool check_dir_exists(const std::string& path); bool is_absolute_path(std::string filename); void remove_directory(std::string dirname); +bool create_directory(const std::string& path); std::string escape_filename_spaces(const std::string& filename); template int GetSize(const T &obj) { return obj.size(); }