mirror of
https://github.com/embarklabs/embark.git
synced 2025-01-11 22:34:24 +00:00
fix(@embark/solidity): handle absolute paths correctly
Detect absolute paths and handle them differently from paths that have not been resolved.
This commit is contained in:
parent
9e4204a492
commit
4b1e126b60
@ -36,8 +36,7 @@ const prepareInitialFile = async (file: File) => {
|
|||||||
return await file.content;
|
return await file.content;
|
||||||
}
|
}
|
||||||
|
|
||||||
let to = file.path.includes(fs.dappPath(".embark")) ? file.path : fs.dappPath(".embark", file.path);
|
const to = file.path.includes(fs.dappPath(".embark")) ? path.normalize(file.path) : fs.dappPath(".embark", file.path);
|
||||||
to = path.normalize(to);
|
|
||||||
if (file.type === Types.dappFile || file.type === Types.custom) {
|
if (file.type === Types.dappFile || file.type === Types.custom) {
|
||||||
if (file.resolver) {
|
if (file.resolver) {
|
||||||
fs.mkdirpSync(path.dirname(to));
|
fs.mkdirpSync(path.dirname(to));
|
||||||
@ -69,11 +68,12 @@ const buildNewFile = (file: File, importPath: string) => {
|
|||||||
return new File({ externalUrl: importPath, type: Types.http });
|
return new File({ externalUrl: importPath, type: Types.http });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
importPath = path.normalize(importPath);
|
||||||
|
|
||||||
// imported from node_modules, ie import "@aragon/os/contracts/acl/ACL.sol"
|
// imported from node_modules, ie import "@aragon/os/contracts/acl/ACL.sol"
|
||||||
if (isNodeModule(importPath)) {
|
if (isUnresolvedNodeModule(importPath)) {
|
||||||
from = resolve(importPath);
|
from = resolve(importPath);
|
||||||
to = importPath.includes(fs.dappPath(".embark")) ? importPath : fs.dappPath(".embark", "node_modules", importPath);
|
to = importPath.includes(fs.dappPath(".embark")) ? importPath : fs.dappPath(".embark", "node_modules", importPath);
|
||||||
to = path.normalize(to);
|
|
||||||
if (from !== to) {
|
if (from !== to) {
|
||||||
fs.copySync(from, to);
|
fs.copySync(from, to);
|
||||||
}
|
}
|
||||||
@ -82,20 +82,30 @@ const buildNewFile = (file: File, importPath: string) => {
|
|||||||
|
|
||||||
// started with node_modules then further imports local paths in it's own repo/directory
|
// started with node_modules then further imports local paths in it's own repo/directory
|
||||||
if (isEmbarkNodeModule(file.path)) {
|
if (isEmbarkNodeModule(file.path)) {
|
||||||
|
if (path.isAbsolute(importPath)) {
|
||||||
|
from = path.normalize(importPath.replace(".embark", "."));
|
||||||
|
to = importPath;
|
||||||
|
} else {
|
||||||
from = path.join(path.dirname(file.path.replace(".embark", ".")), importPath);
|
from = path.join(path.dirname(file.path.replace(".embark", ".")), importPath);
|
||||||
to = path.normalize(path.join(path.dirname(file.path), importPath));
|
to = path.join(path.dirname(file.path), importPath);
|
||||||
fs.copySync(from, to);
|
fs.copySync(from, to);
|
||||||
|
}
|
||||||
return new File({ path: to, type: Types.dappFile, originalPath: from });
|
return new File({ path: to, type: Types.dappFile, originalPath: from });
|
||||||
}
|
}
|
||||||
|
|
||||||
// local import, ie import "../path/to/contract" or "./path/to/contract"
|
// local import, ie import "../path/to/contract" or "./path/to/contract"
|
||||||
|
if (path.isAbsolute(importPath)) {
|
||||||
|
from = path.normalize(importPath.replace(".embark", "."));
|
||||||
|
to = importPath;
|
||||||
|
} else {
|
||||||
from = path.join(path.dirname(file.path.replace(".embark", ".")), importPath);
|
from = path.join(path.dirname(file.path.replace(".embark", ".")), importPath);
|
||||||
if (importPath === "remix_tests.sol") {
|
if (importPath === "remix_tests.sol") {
|
||||||
to = path.normalize(fs.dappPath(".embark", "remix_tests.sol"));
|
to = fs.dappPath(".embark", "remix_tests.sol");
|
||||||
} else {
|
} else {
|
||||||
to = path.normalize(path.join(path.dirname(file.path), importPath));
|
to = path.join(path.dirname(file.path), importPath);
|
||||||
fs.copySync(from, to);
|
fs.copySync(from, to);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return new File({ path: to, type: Types.dappFile, originalPath: from });
|
return new File({ path: to, type: Types.dappFile, originalPath: from });
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -131,8 +141,11 @@ const isEmbarkNodeModule = (input: string) => {
|
|||||||
return path.normalize(input).includes(path.normalize(".embark/node_modules"));
|
return path.normalize(input).includes(path.normalize(".embark/node_modules"));
|
||||||
};
|
};
|
||||||
|
|
||||||
const isNodeModule = (input: string) => {
|
const isUnresolvedNodeModule = (input: string) => {
|
||||||
return !(input.startsWith(".") || input.startsWith("..")) && resolve(input);
|
if (path.isAbsolute(input)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return !(input.startsWith(".") || input.startsWith("..")) && !!resolve(input);
|
||||||
};
|
};
|
||||||
|
|
||||||
const isHttp = (input: string) => {
|
const isHttp = (input: string) => {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user