file_util.cc 4.24 KB
Newer Older
Minjie Wang's avatar
Minjie Wang committed
1
2
3
4
/*!
 *  Copyright (c) 2017 by Contributors
 * \file file_util.cc
 */
5
6
7
#include "file_util.h"

#include <dgl/runtime/serializer.h>
Minjie Wang's avatar
Minjie Wang committed
8
9
#include <dmlc/json.h>
#include <dmlc/logging.h>
10

Minjie Wang's avatar
Minjie Wang committed
11
#include <fstream>
12
#include <unordered_map>
13
#include <vector>
Minjie Wang's avatar
Minjie Wang committed
14

15
namespace dgl {
Minjie Wang's avatar
Minjie Wang committed
16
17
18
19
20
namespace runtime {

void FunctionInfo::Save(dmlc::JSONWriter* writer) const {
  std::vector<std::string> sarg_types(arg_types.size());
  for (size_t i = 0; i < arg_types.size(); ++i) {
21
    sarg_types[i] = DGLDataType2String(arg_types[i]);
Minjie Wang's avatar
Minjie Wang committed
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
  }
  writer->BeginObject();
  writer->WriteObjectKeyValue("name", name);
  writer->WriteObjectKeyValue("arg_types", sarg_types);
  writer->WriteObjectKeyValue("thread_axis_tags", thread_axis_tags);
  writer->EndObject();
}

void FunctionInfo::Load(dmlc::JSONReader* reader) {
  dmlc::JSONObjectReadHelper helper;
  std::vector<std::string> sarg_types;
  helper.DeclareField("name", &name);
  helper.DeclareField("arg_types", &sarg_types);
  helper.DeclareField("thread_axis_tags", &thread_axis_tags);
  helper.ReadAllFields(reader);
  arg_types.resize(sarg_types.size());
  for (size_t i = 0; i < arg_types.size(); ++i) {
39
    arg_types[i] = String2DGLDataType(sarg_types[i]);
Minjie Wang's avatar
Minjie Wang committed
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
  }
}

void FunctionInfo::Save(dmlc::Stream* writer) const {
  writer->Write(name);
  writer->Write(arg_types);
  writer->Write(thread_axis_tags);
}

bool FunctionInfo::Load(dmlc::Stream* reader) {
  if (!reader->Read(&name)) return false;
  if (!reader->Read(&arg_types)) return false;
  if (!reader->Read(&thread_axis_tags)) return false;
  return true;
}

56
57
std::string GetFileFormat(
    const std::string& file_name, const std::string& format) {
Minjie Wang's avatar
Minjie Wang committed
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
  std::string fmt = format;
  if (fmt.length() == 0) {
    if (file_name.find(".signed.so") != std::string::npos) return "sgx";
    size_t pos = file_name.find_last_of(".");
    if (pos != std::string::npos) {
      return file_name.substr(pos + 1, file_name.length() - pos - 1);
    } else {
      return "";
    }
  } else {
    return format;
  }
}

std::string GetCacheDir() {
  char* env_cache_dir;
74
  if ((env_cache_dir = getenv("DGL_CACHE_DIR"))) return env_cache_dir;
Minjie Wang's avatar
Minjie Wang committed
75
  if ((env_cache_dir = getenv("XDG_CACHE_HOME"))) {
76
    return std::string(env_cache_dir) + "/dgl";
Minjie Wang's avatar
Minjie Wang committed
77
78
  }
  if ((env_cache_dir = getenv("HOME"))) {
79
    return std::string(env_cache_dir) + "/.cache/dgl";
Minjie Wang's avatar
Minjie Wang committed
80
81
82
83
84
85
86
87
88
89
90
  }
  return ".";
}

std::string GetFileBasename(const std::string& file_name) {
  size_t last_slash = file_name.find_last_of("/");
  if (last_slash == std::string::npos) return file_name;
  return file_name.substr(last_slash + 1);
}

std::string GetMetaFilePath(const std::string& file_name) {
91
  size_t pos = file_name.find_last_of(".");
Minjie Wang's avatar
Minjie Wang committed
92
  if (pos != std::string::npos) {
93
    return file_name.substr(0, pos) + ".dgl_meta.json";
Minjie Wang's avatar
Minjie Wang committed
94
  } else {
95
    return file_name + ".dgl_meta.json";
Minjie Wang's avatar
Minjie Wang committed
96
97
98
  }
}

99
void LoadBinaryFromFile(const std::string& file_name, std::string* data) {
Minjie Wang's avatar
Minjie Wang committed
100
101
102
103
104
105
106
107
108
109
  std::ifstream fs(file_name, std::ios::in | std::ios::binary);
  CHECK(!fs.fail()) << "Cannot open " << file_name;
  // get its size:
  fs.seekg(0, std::ios::end);
  size_t size = static_cast<size_t>(fs.tellg());
  fs.seekg(0, std::ios::beg);
  data->resize(size);
  fs.read(&(*data)[0], size);
}

110
void SaveBinaryToFile(const std::string& file_name, const std::string& data) {
Minjie Wang's avatar
Minjie Wang committed
111
112
113
114
115
116
117
118
119
120
121
122
123
  std::ofstream fs(file_name, std::ios::out | std::ios::binary);
  CHECK(!fs.fail()) << "Cannot open " << file_name;
  fs.write(&data[0], data.length());
}

void SaveMetaDataToFile(
    const std::string& file_name,
    const std::unordered_map<std::string, FunctionInfo>& fmap) {
  std::string version = "0.1.0";
  std::ofstream fs(file_name.c_str());
  CHECK(!fs.fail()) << "Cannot open file " << file_name;
  dmlc::JSONWriter writer(&fs);
  writer.BeginObject();
124
  writer.WriteObjectKeyValue("dgl_version", version);
Minjie Wang's avatar
Minjie Wang committed
125
126
127
128
129
130
131
132
133
134
135
136
137
  writer.WriteObjectKeyValue("func_info", fmap);
  writer.EndObject();
  fs.close();
}

void LoadMetaDataFromFile(
    const std::string& file_name,
    std::unordered_map<std::string, FunctionInfo>* fmap) {
  std::ifstream fs(file_name.c_str());
  CHECK(!fs.fail()) << "Cannot open file " << file_name;
  std::string version;
  dmlc::JSONReader reader(&fs);
  dmlc::JSONObjectReadHelper helper;
138
  helper.DeclareField("dgl_version", &version);
Minjie Wang's avatar
Minjie Wang committed
139
140
141
142
143
144
  helper.DeclareField("func_info", fmap);
  helper.ReadAllFields(&reader);
  fs.close();
}

}  // namespace runtime
145
}  // namespace dgl