Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
风弥漫了夏天
nvm-windows
提交
44719321
N
nvm-windows
项目概览
风弥漫了夏天
/
nvm-windows
与 Fork 源项目一致
从无法访问的项目Fork
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
N
nvm-windows
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
44719321
编写于
9月 19, 2015
作者:
M
Michael-Rainabba Richardson
浏览文件
操作
浏览文件
下载
差异文件
Finish newx64FolderNameSupport
上级
32b87547
85d8e9a2
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
41 addition
and
32 deletion
+41
-32
nvm.iss
nvm.iss
+1
-1
src/nvm.go
src/nvm.go
+1
-1
src/nvm/web/web.go
src/nvm/web/web.go
+39
-30
未找到文件。
nvm.iss
浏览文件 @
44719321
#define MyAppName "NVM for Windows"
#define MyAppShortName "nvm"
#define MyAppLCShortName "nvm"
#define MyAppVersion "1.
0.6
"
#define MyAppVersion "1.
1.0
"
#define MyAppPublisher "Ecor Ventures, LLC"
#define MyAppURL "http://github.com/coreybutler/nvm"
#define MyAppExeName "nvm.exe"
...
...
src/nvm.go
浏览文件 @
44719321
...
...
@@ -18,7 +18,7 @@ import (
)
const
(
NvmVersion
=
"1.
0.6
"
NvmVersion
=
"1.
1.0
"
)
type
Environment
struct
{
...
...
src/nvm/web/web.go
浏览文件 @
44719321
...
...
@@ -59,26 +59,42 @@ func GetNodeJS(root string, v string, a string) bool {
a
=
arch
.
Validate
(
a
)
url
:=
""
vpre
:=
""
vers
:=
strings
.
Fields
(
strings
.
Replace
(
v
,
"."
,
" "
,
-
1
))
main
,
_
:=
strconv
.
ParseInt
(
vers
[
0
],
0
,
0
)
if
a
==
"32"
{
url
=
"http://nodejs.org/dist/v"
+
v
+
"/node.exe"
}
else
{
if
!
IsNode64bitAvailable
(
v
)
{
fmt
.
Println
(
"Node.js v"
+
v
+
" is only available in 32-bit."
)
return
false
if
main
>
0
{
vpre
=
"win-x86/"
}
else
{
vpre
=
""
}
}
else
if
a
==
"64"
{
if
main
>
0
{
vpre
=
"win-x64/"
}
else
{
vpre
=
"x64/"
}
url
=
"http://nodejs.org/dist/v"
+
v
+
"/x64/node.exe"
}
fileName
:=
root
+
"
\\
v"
+
v
+
"
\\
node"
+
a
+
".exe"
fmt
.
Printf
(
"Downloading node.js version "
+
v
+
" ("
+
a
+
"-bit)... "
)
url
:=
getNodeUrl
(
v
,
vpre
);
if
Download
(
url
,
fileName
)
{
fmt
.
Printf
(
"Complete
\n
"
)
return
true
if
url
==
""
{
//No url should mean this version/arch isn't available
fmt
.
Println
(
"Node.js v"
+
v
+
" "
+
a
+
"bit isn't available right now."
)
}
else
{
return
false
fileName
:=
root
+
"
\\
v"
+
v
+
"
\\
node"
+
a
+
".exe"
fmt
.
Printf
(
"Downloading node.js version "
+
v
+
" ("
+
a
+
"-bit)... "
)
if
Download
(
url
,
fileName
)
{
fmt
.
Printf
(
"Complete
\n
"
)
return
true
}
else
{
return
false
}
}
return
false
}
...
...
@@ -126,23 +142,16 @@ func GetRemoteTextFile(url string) string {
return
""
}
func
IsNode64bitAvailable
(
v
string
)
bool
{
if
v
==
"latest"
{
return
true
}
// Anything below version 8 doesn't have a 64 bit version
vers
:=
strings
.
Fields
(
strings
.
Replace
(
v
,
"."
,
" "
,
-
1
))
main
,
_
:=
strconv
.
ParseInt
(
vers
[
0
],
0
,
0
)
minor
,
_
:=
strconv
.
ParseInt
(
vers
[
1
],
0
,
0
)
if
main
==
0
&&
minor
<
8
{
return
false
}
func
getNodeUrl
(
v
string
,
vpre
string
)
string
{
url
:=
"http://nodejs.org/dist/v"
+
v
+
"/"
+
vpre
+
"/node.exe"
// Check online to see if a 64 bit version exists
res
,
err
:=
client
.
Head
(
"http://nodejs.org/dist/v"
+
v
+
"/x64/node.exe"
)
res
,
err
:=
client
.
Head
(
url
)
if
err
!=
nil
{
return
false
return
""
}
if
res
.
StatusCode
==
200
{
return
url
}
else
{
return
""
}
return
res
.
StatusCode
==
200
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录