Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
SkyAPM
SkyAPM-nodejs
提交
339e85dd
S
SkyAPM-nodejs
项目概览
SkyAPM
/
SkyAPM-nodejs
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
SkyAPM-nodejs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
339e85dd
编写于
8月 17, 2018
作者:
X
Xin,Zhang
提交者:
wu-sheng
8月 17, 2018
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fetch the module version (#22)
上级
95815a08
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
15 addition
and
2 deletion
+15
-2
lib/require-module-hook.js
lib/require-module-hook.js
+15
-2
未找到文件。
lib/require-module-hook.js
浏览文件 @
339e85dd
...
...
@@ -20,6 +20,7 @@
const
Module
=
require
(
"
module
"
);
const
resolve
=
require
(
"
resolve
"
);
const
path
=
require
(
"
path
"
);
const
fs
=
require
(
"
fs
"
);
module
.
exports
=
hook
;
...
...
@@ -38,7 +39,8 @@ function hook(modules, requireCallback) {
let
moduleName
=
""
;
let
matchModuleName
=
""
;
let
enhanceFile
=
""
;
let
version
=
""
;
let
version
=
undefined
;
let
basedir
=
undefined
;
if
(
enhancedModuleCache
.
hasOwnProperty
(
filename
))
{
return
enhancedModuleCache
[
filename
];
...
...
@@ -56,7 +58,7 @@ function hook(modules, requireCallback) {
moduleName
=
isWithScope
?
pathSegment
[
index
+
1
]
+
"
/
"
+
pathSegment
[
index
+
2
]
:
pathSegment
[
index
+
1
];
let
basedir
=
pathSegment
.
slice
(
0
,
index
+
(
isWithScope
?
3
:
2
)).
join
(
path
.
sep
);
basedir
=
pathSegment
.
slice
(
0
,
index
+
(
isWithScope
?
3
:
2
)).
join
(
path
.
sep
);
try
{
let
res
=
resolve
.
sync
(
moduleName
,
{
basedir
:
basedir
});
if
(
res
!==
filename
)
{
...
...
@@ -73,6 +75,17 @@ function hook(modules, requireCallback) {
}
if
(
modules
&&
modules
.
indexOf
(
matchModuleName
)
===
-
1
)
return
exports
;
// get version. Because of we enhance Module.prototype.require, so we can't fetch the version by execute
// `require(basedir + path.sep + "package.json")` method
if
(
basedir
)
{
const
packageJson
=
path
.
join
(
basedir
,
"
package.json
"
);
try
{
version
=
JSON
.
parse
(
fs
.
readFileSync
(
packageJson
)).
version
;
}
catch
(
e
)
{
}
}
if
(
!
enhancedModuleCache
.
hasOwnProperty
(
filename
))
{
enhancedModuleCache
[
filename
]
=
exports
;
enhancedModuleCache
[
filename
]
=
requireCallback
(
exports
,
moduleName
,
version
,
enhanceFile
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录