liyujie
2025-08-28 786ff4f4ca2374bdd9177f2e24b503d43e7a3b93
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*
 * Copyright (C) 2019 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
 
#include "linkerconfig/namespace.h"
 
#include "linkerconfig/log.h"
 
#define LOG_TAG "linkerconfig"
 
namespace android {
namespace linkerconfig {
namespace modules {
 
constexpr const char* kDataAsanPath = "/data/asan";
 
void Namespace::WritePathString(ConfigWriter& writer,
                                const std::string& path_type,
                                const std::vector<std::string>& path_list) {
  std::string prefix = path_type + ".paths ";
  bool is_first = true;
  for (auto& path : path_list) {
    writer.WriteLine(prefix + (is_first ? "= " : "+= ") + path);
    is_first = false;
  }
}
 
std::shared_ptr<Link> Namespace::CreateLink(const std::string& target_namespace,
                                            bool allow_all_shared_libs) {
  auto new_link =
      std::make_shared<Link>(name_, target_namespace, allow_all_shared_libs);
 
  if (links_.find(target_namespace) != links_.end()) {
    LOG(INFO) << "Link to " << target_namespace
              << " already exists. Overwriting link.";
  }
 
  links_[target_namespace] = new_link;
  return new_link;
}
 
void Namespace::WriteConfig(ConfigWriter& writer) {
  writer.SetPrefix("namespace." + name_ + ".");
 
  writer.WriteLine("isolated = %s", is_isolated_ ? "true" : "false");
 
  if (is_visible_) {
    writer.WriteLine("visible = true");
  }
 
  WritePathString(writer, "search", search_paths_);
  WritePathString(writer, "permitted", permitted_paths_);
  WritePathString(writer, "asan.search", asan_search_paths_);
  WritePathString(writer, "asan.permitted", asan_permitted_paths_);
 
  if (!links_.empty()) {
    std::string link_list = "";
 
    bool is_first = true;
    for (auto& link : links_) {
      if (!is_first) {
        link_list += ",";
      }
      link_list += link.first;
      is_first = false;
    }
 
    writer.WriteLine("links = " + link_list);
 
    for (auto& link : links_) {
      link.second->WriteConfig(writer);
    }
  }
 
  writer.ResetPrefix();
}
 
void Namespace::AddSearchPath(const std::string& path, bool in_asan,
                              bool with_data_asan) {
  search_paths_.push_back(path);
 
  if (in_asan) {
    asan_search_paths_.push_back(path);
    if (with_data_asan) {
      asan_search_paths_.push_back(kDataAsanPath + path);
    }
  }
}
 
void Namespace::AddPermittedPath(const std::string& path, bool in_asan,
                                 bool with_data_asan) {
  permitted_paths_.push_back(path);
 
  if (in_asan) {
    asan_permitted_paths_.push_back(path);
    if (with_data_asan) {
      asan_permitted_paths_.push_back(kDataAsanPath + path);
    }
  }
}
 
}  // namespace modules
}  // namespace linkerconfig
}  // namespace android