Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
c0539345
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
c0539345
编写于
10月 03, 2017
作者:
S
serb
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8185325: Improve GTK initialization
Reviewed-by: azvegint, rhalade, mschoene
上级
5f7ce206
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
28 addition
and
33 deletion
+28
-33
src/solaris/native/sun/awt/gtk2_interface.c
src/solaris/native/sun/awt/gtk2_interface.c
+28
-33
未找到文件。
src/solaris/native/sun/awt/gtk2_interface.c
浏览文件 @
c0539345
/*
* Copyright (c) 2005, 201
3
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2005, 201
7
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
...
...
@@ -843,46 +843,41 @@ gboolean gtk2_load(JNIEnv *env)
}
/*
* Strip the AT-SPI GTK_MODULE
s
if present
* Strip the AT-SPI GTK_MODULE
S
if present
*/
gtk_modules_env
=
getenv
(
"GTK_MODULES"
);
if
(
gtk_modules_env
&&
strstr
(
gtk_modules_env
,
"atk-bridge"
)
||
gtk_modules_env
&&
strstr
(
gtk_modules_env
,
"gail"
))
{
/* the new env will be smaller than the old one */
gchar
*
s
,
*
new_env
=
SAFE_SIZE_STRUCT_ALLOC
(
malloc
,
sizeof
(
ENV_PREFIX
),
1
,
strlen
(
gtk_modules_env
));
if
(
new_env
!=
NULL
)
{
/* careful, strtok modifies its args */
gchar
*
tmp_env
=
strdup
(
gtk_modules_env
);
strcpy
(
new_env
,
ENV_PREFIX
);
/* strip out 'atk-bridge' and 'gail' */
size_t
PREFIX_LENGTH
=
strlen
(
ENV_PREFIX
)
;
while
(
s
=
strtok
(
tmp_env
,
":"
))
{
if
((
!
strstr
(
s
,
"atk-bridge"
))
&&
(
!
strstr
(
s
,
"gail"
)))
{
if
(
strlen
(
new_env
)
>
PREFIX_LENGTH
)
{
new_env
=
strcat
(
new_env
,
":"
);
if
((
gtk_modules_env
&&
strstr
(
gtk_modules_env
,
"atk-bridge"
))
||
(
gtk_modules_env
&&
strstr
(
gtk_modules_env
,
"gail"
)))
{
/* careful, strtok modifies its args */
gchar
*
tmp_env
=
strdup
(
gtk_modules_env
);
if
(
tmp_env
)
{
/* the new env will be smaller than the old one */
gchar
*
s
,
*
new_env
=
SAFE_SIZE_STRUCT_ALLOC
(
malloc
,
sizeof
(
ENV_PREFIX
),
1
,
strlen
(
gtk_modules_env
));
if
(
new_env
)
{
strcpy
(
new_env
,
ENV_PREFIX
);
/* strip out 'atk-bridge' and 'gail' */
size_t
PREFIX_LENGTH
=
strlen
(
ENV_PREFIX
);
gchar
*
tmp_ptr
=
NULL
;
for
(
s
=
strtok_r
(
tmp_env
,
":"
,
&
tmp_ptr
);
s
;
s
=
strtok_r
(
NULL
,
":"
,
&
tmp_ptr
))
{
if
((
!
strstr
(
s
,
"atk-bridge"
))
&&
(
!
strstr
(
s
,
"gail"
)))
{
if
(
strlen
(
new_env
)
>
PREFIX_LENGTH
)
{
new_env
=
strcat
(
new_env
,
":"
);
}
new_env
=
strcat
(
new_env
,
s
);
}
new_env
=
strcat
(
new_env
,
s
);
}
if
(
tmp_env
)
{
free
(
tmp_env
);
tmp_env
=
NULL
;
/* next call to strtok arg1==NULL */
if
(
putenv
(
new_env
)
!=
0
)
{
/* no free() on success, putenv() doesn't copy string */
free
(
new_env
);
}
}
putenv
(
new_env
);
free
(
new_env
);
free
(
tmp_env
);
free
(
tmp_env
);
}
}
/*
* GTK should be initialized with gtk_init_check() before use.
*
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录