mirror of
https://github.com/topjohnwu/Magisk.git
synced 2025-01-12 12:33:37 +00:00
magisk_node: check target exists
This commit is contained in:
parent
d35072d4e6
commit
00d3cb0908
@ -522,6 +522,10 @@ public:
|
|||||||
explicit magisk_node(const char *name) : node_entry(name, DT_REG, this) {}
|
explicit magisk_node(const char *name) : node_entry(name, DT_REG, this) {}
|
||||||
|
|
||||||
void mount() override {
|
void mount() override {
|
||||||
|
const string src = MAGISKTMP + "/" + name();
|
||||||
|
if (access(src.data(), F_OK))
|
||||||
|
return;
|
||||||
|
|
||||||
const string &dir_name = parent()->node_path();
|
const string &dir_name = parent()->node_path();
|
||||||
if (name() == "magisk") {
|
if (name() == "magisk") {
|
||||||
for (int i = 0; applet_names[i]; ++i) {
|
for (int i = 0; applet_names[i]; ++i) {
|
||||||
@ -534,7 +538,7 @@ public:
|
|||||||
VLOGD("create", "./magiskpolicy", dest.data());
|
VLOGD("create", "./magiskpolicy", dest.data());
|
||||||
xsymlink("./magiskpolicy", dest.data());
|
xsymlink("./magiskpolicy", dest.data());
|
||||||
}
|
}
|
||||||
create_and_mount(MAGISKTMP + "/" + name());
|
create_and_mount(src);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -624,7 +628,7 @@ void magic_mount() {
|
|||||||
if (!system->is_empty()) {
|
if (!system->is_empty()) {
|
||||||
// Handle special read-only partitions
|
// Handle special read-only partitions
|
||||||
for (const char *part : { "/vendor", "/product", "/system_ext" }) {
|
for (const char *part : { "/vendor", "/product", "/system_ext" }) {
|
||||||
struct stat st;
|
struct stat st{};
|
||||||
if (lstat(part, &st) == 0 && S_ISDIR(st.st_mode)) {
|
if (lstat(part, &st) == 0 && S_ISDIR(st.st_mode)) {
|
||||||
if (auto old = system->extract(part + 1)) {
|
if (auto old = system->extract(part + 1)) {
|
||||||
auto new_node = new root_node(old);
|
auto new_node = new root_node(old);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user