Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
4378e7ea
R
Rust
项目概览
int
/
Rust
11 个月 前同步成功
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
Rust
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
4378e7ea
编写于
7月 25, 2012
作者:
B
Ben Blum
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix os::env race (#2870)
上级
43867bf6
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
30 addition
and
12 deletion
+30
-12
src/libcore/os.rs
src/libcore/os.rs
+30
-12
未找到文件。
src/libcore/os.rs
浏览文件 @
4378e7ea
...
...
@@ -41,7 +41,6 @@
export
as_c_charp
,
fill_charp_buf
;
extern
mod
rustrt
{
fn
rust_env_pairs
()
->
~
[
~
str
];
fn
rust_getcwd
()
->
~
str
;
fn
rust_path_is_dir
(
path
:
*
libc
::
c_char
)
->
c_int
;
fn
rust_path_exists
(
path
:
*
libc
::
c_char
)
->
c_int
;
...
...
@@ -52,16 +51,6 @@
}
fn
env
()
->
~
[(
~
str
,
~
str
)]
{
let
mut
pairs
=
~
[];
for
vec
::
each
(
rustrt
::
rust_env_pairs
())
|
p
|
{
let
vs
=
str
::
splitn_char
(
p
,
'='
,
1u
);
assert
vec
::
len
(
vs
)
==
2u
;
vec
::
push
(
pairs
,
(
vs
[
0
],
vs
[
1
]));
}
ret
pairs
;
}
const
tmpbuf_sz
:
uint
=
1000u
;
fn
as_c_charp
<
T
>
(
s
:
~
str
,
f
:
fn
(
*
c_char
)
->
T
)
->
T
{
...
...
@@ -130,11 +119,16 @@ fn setenv(n: ~str, v: ~str) {
global_env
::
setenv
(
n
,
v
)
}
fn
env
()
->
~
[(
~
str
,
~
str
)]
{
global_env
::
env
()
}
mod
global_env
{
//! Internal module for serializing access to getenv/setenv
export
getenv
;
export
setenv
;
export
env
;
extern
mod
rustrt
{
fn
rust_global_env_chan_ptr
()
->
*
libc
::
uintptr_t
;
...
...
@@ -142,7 +136,8 @@ mod global_env {
enum
msg
{
msg_getenv
(
~
str
,
comm
::
chan
<
option
<~
str
>>
),
msg_setenv
(
~
str
,
~
str
,
comm
::
chan
<
()
>
)
msg_setenv
(
~
str
,
~
str
,
comm
::
chan
<
()
>
),
msg_env
(
comm
::
chan
<~
[(
~
str
,
~
str
)]
>
)
}
fn
getenv
(
n
:
~
str
)
->
option
<~
str
>
{
...
...
@@ -159,6 +154,13 @@ fn setenv(n: ~str, v: ~str) {
comm
::
recv
(
po
)
}
fn
env
()
->
~
[(
~
str
,
~
str
)]
{
let
env_ch
=
get_global_env_chan
();
let
po
=
comm
::
port
();
comm
::
send
(
env_ch
,
msg_env
(
comm
::
chan
(
po
)));
comm
::
recv
(
po
)
}
fn
get_global_env_chan
()
->
comm
::
chan
<
msg
>
{
let
global_ptr
=
rustrt
::
rust_global_env_chan_ptr
();
let
task_build_fn
=
||
{
...
...
@@ -183,6 +185,9 @@ fn global_env_task(msg_po: comm::port<msg>) {
either
::
left
(
msg_setenv
(
n
,
v
,
resp_ch
))
{
comm
::
send
(
resp_ch
,
impl
::
setenv
(
n
,
v
))
}
either
::
left
(
msg_env
(
resp_ch
))
{
comm
::
send
(
resp_ch
,
impl
::
env
())
}
either
::
right
(
_
)
{
break
;
}
...
...
@@ -193,6 +198,19 @@ fn global_env_task(msg_po: comm::port<msg>) {
}
mod
impl
{
extern
mod
rustrt
{
fn
rust_env_pairs
()
->
~
[
~
str
];
}
fn
env
()
->
~
[(
~
str
,
~
str
)]
{
let
mut
pairs
=
~
[];
for
vec
::
each
(
rustrt
::
rust_env_pairs
())
|
p
|
{
let
vs
=
str
::
splitn_char
(
p
,
'='
,
1u
);
assert
vec
::
len
(
vs
)
==
2u
;
vec
::
push
(
pairs
,
(
vs
[
0
],
vs
[
1
]));
}
ret
pairs
;
}
#[cfg(unix)]
fn
getenv
(
n
:
~
str
)
->
option
<~
str
>
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录