forked from pytorch/pytorch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
import_export_helpers.cpp
54 lines (45 loc) · 1.56 KB
/
import_export_helpers.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#include <caffe2/serialize/inline_container.h>
#include <torch/csrc/jit/import_export_helpers.h>
#include <torch/csrc/jit/source_range.h>
#include <torch/csrc/jit/source_range_serialization_impl.h>
#include <c10/util/Exception.h>
#include <algorithm>
namespace torch {
namespace jit {
static const std::string kExportSuffix = "py";
std::string qualifierToArchivePath(
const std::string& qualifier,
const std::string& export_prefix) {
std::string path = qualifier;
std::replace_if(
path.begin(), path.end(), [](char c) { return c == '.'; }, '/');
return export_prefix + path + "." + kExportSuffix;
}
std::shared_ptr<Source> findSourceInArchiveFromQualifier(
caffe2::serialize::PyTorchStreamReader& reader,
const std::string& export_prefix,
const std::string& qualifier) {
const std::string path = qualifierToArchivePath(qualifier, export_prefix);
if (!reader.hasRecord(path)) {
return nullptr;
}
at::DataPtr data;
size_t size;
std::tie(data, size) = reader.getRecord(path);
std::shared_ptr<ConcreteSourceRangeUnpickler> gen_ranges = nullptr;
std::string debug_file = path + ".debug_pkl";
if (reader.hasRecord(debug_file)) {
at::DataPtr debug_data;
size_t debug_size;
std::tie(debug_data, debug_size) = reader.getRecord(debug_file);
gen_ranges = std::make_shared<ConcreteSourceRangeUnpickler>(
std::move(debug_data), debug_size);
}
return std::make_shared<Source>(
std::string(static_cast<const char*>(data.get()), size),
path,
1,
gen_ranges);
}
} // namespace jit
} // namespace torch