#include <basis/guards.h>
#include <basis/mutex.h>
#include <basis/utf_conversion.h>
+#include <filesystem/directory.h>
#include <filesystem/filename.h>
#include <mathematics/chaos.h>
#include <structures/static_memory_gremlin.h>
// command line are all separated by zero characters.
__check_once_app_path = filebuff;
delete [] filebuff;
+//printf("got an app name before chewing: %s\n", __check_once_app_path.s());
// clean out quote characters from the name.
for (int i = __check_once_app_path.length() - 1; i >= 0; i--) {
if (__check_once_app_path[i] == '"') __check_once_app_path.zap(i, i);
filename testing(__check_once_app_path);
if (testing.had_directory()) return __check_once_app_path; // all set.
-//hmmm: the below might be better off as a find app in path method, which relies on which.
+//printf("no dir part found, app name after chewing: %s\n", __check_once_app_path.s());
+//hmmm: the below might be better off as a find app in path method, which relies on which.
// there was no directory component, so we'll try to guess one.
- astring temp_filename(environment::get("TMP")
+ astring temp_filename(environment::TMP()
+ a_sprintf("/zz_cmdfind.%d", chaos().inclusive(0, 999999999)));
system((astring("which ") + __check_once_app_path + " >" + temp_filename).s());
FILE *which_file = fopen(temp_filename.s(), "r");
// deprecated; better to use the /proc/pid/cmdline file.
astring application_configuration::query_for_process_info()
{
-// FUNCDEF("query_for_process_info");
+ FUNCDEF("query_for_process_info");
astring to_return = "unknown";
// we ask the operating system about our process identifier and store
// the results in a temporary file.
fclose(output); \
unlink(tmpfile.s()); \
} \
- astring home_dir = env_string("HOME"); \
+ astring home_dir = environment::get("HOME"); \
to_return = home_dir + "/failed_to_determine.exe"; \
}
astring application_configuration::application_name()
{
-// FUNCDEF("application_name");
+ FUNCDEF("application_name");
astring to_return;
#ifdef __APPLE__
char buffer[MAX_ABS_PATH] = { '\0' };
//////////////
-const int MAX_LOG_PATH = 200;
+////const int MAX_LOG_PATH = 512;
// the maximum length of the entry stored for the log path.
-/*
-astring application_configuration::installation_root()
-{
- astring to_return = read_item(LOCAL_FOLDER_NAME());
- if (!to_return) {
- // well, if this other guy has a path, we'll give that back. otherwise,
- // we don't know what the path should be at all.
- to_return = filename(application_configuration_file()).dirname();
- }
- return to_return;
-}
-*/
-
astring application_configuration::get_logging_directory()
{
- // start with the root of our installation.
- astring def_log = application_directory();
-///installation_root();
+ // new scheme is to just use the temporary directory, which can vary per user
+ // and which hopefully is always set to something usable.
+ astring def_log = environment::TMP();
// add logs directory underneath that.
def_log += "/logs";
// add the subdirectory for logs.
// get the entry for the logging path.
if (!log_dir) {
// if the entry was absent, we set it.
+//printf("did not find log dir in config file\n");
ini_configurator ini(application_configuration_file(),
ini_configurator::RETURN_ONLY,
ini_configurator::APPLICATION_DIRECTORY);
// they gave us something. let's replace the environment variables
// in their string so we resolve paths and such.
log_dir = parser_bits::substitute_env_vars(log_dir);
+//printf("%s", (char *)a_sprintf("got log dir with %s value\n", log_dir.s()).s());
}
// now we make sure the directory exists.
- struct stat to_fill;
- int stat_ret = stat(log_dir.observe(), &to_fill);
- if (stat_ret || !(to_fill.st_mode & S_IFDIR) ) {
- // if it's not anything yet or if it's not a directory, then we need
- // to create it.
-//if it's something besides a directory... should it be deleted?
+ filename testing(log_dir);
+ if (!testing.exists()) {
+ bool okay = directory::make_directory(log_dir);
+ if (!okay) {
+ LOG(astring("failed to create logging directory: ") + log_dir);
+ // return a directory almost guaranteed to exist; best we can do in this case.
#ifdef __UNIX__
- int mk_ret = mkdir(log_dir.s(), 0777);
+ return "/tmp";
#endif
#ifdef __WIN32__
- int mk_ret = mkdir(log_dir.s());
+ return "c:/";
#endif
- if (mk_ret) return "";
-//can't have a log file if we can't make the directory successfully???
+ }
}
-
+
return log_dir;
}
astring application_configuration::make_logfile_name(const astring &base_name)
{ return get_logging_directory() + "/" + base_name; }
-///astring application_configuration::core_bin_directory() { return read_item("core_bin"); }
-
astring application_configuration::read_item(const astring &key_name)
{
filename ini_name = application_configuration_file();