Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
6b2d1634
D
dbeaver
项目概览
suliangchun
/
dbeaver
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dbeaver
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
6b2d1634
编写于
12月 13, 2019
作者:
S
Serge Rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#5172 Active catalog change (generic)
上级
1cf3f785
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
24 addition
and
13 deletion
+24
-13
plugins/org.jkiss.dbeaver.ui.navigator/src/org/jkiss/dbeaver/ui/actions/datasource/SelectActiveSchemaHandler.java
...aver/ui/actions/datasource/SelectActiveSchemaHandler.java
+24
-13
未找到文件。
plugins/org.jkiss.dbeaver.ui.navigator/src/org/jkiss/dbeaver/ui/actions/datasource/SelectActiveSchemaHandler.java
浏览文件 @
6b2d1634
...
...
@@ -230,7 +230,7 @@ public class SelectActiveSchemaHandler extends AbstractDataSourceHandler impleme
}
}
private
static
void
changeDataBaseSelection
(
DBPDataSourceContainer
dsContainer
,
DBCExecutionContext
executionContext
,
@Nullable
String
curInstanceName
,
@Nullable
String
newInstanceName
,
@N
otNull
String
newSchemaName
)
{
private
static
void
changeDataBaseSelection
(
DBPDataSourceContainer
dsContainer
,
DBCExecutionContext
executionContext
,
@Nullable
String
curInstanceName
,
@Nullable
String
newInstanceName
,
@N
ullable
String
newSchemaName
)
{
if
(
dsContainer
!=
null
&&
dsContainer
.
isConnected
())
{
final
DBPDataSource
dataSource
=
dsContainer
.
getDataSource
();
new
AbstractJob
(
"Change active database"
)
{
...
...
@@ -261,7 +261,7 @@ public class SelectActiveSchemaHandler extends AbstractDataSourceHandler impleme
}
@SuppressWarnings
(
"unchecked"
)
private
static
void
changeDefaultObject
(
DBRProgressMonitor
monitor
,
DBSObjectContainer
rootContainer
,
DBCExecutionContextDefaults
contextDefaults
,
@Nullable
String
newInstanceName
,
@Nullable
String
curInstanceName
,
@N
otNull
String
newSchemaName
)
throws
DBException
{
private
static
void
changeDefaultObject
(
DBRProgressMonitor
monitor
,
DBSObjectContainer
rootContainer
,
DBCExecutionContextDefaults
contextDefaults
,
@Nullable
String
newInstanceName
,
@Nullable
String
curInstanceName
,
@N
ullable
String
newSchemaName
)
throws
DBException
{
DBSCatalog
newCatalog
=
null
;
DBSSchema
newSchema
=
null
;
...
...
@@ -271,14 +271,16 @@ public class SelectActiveSchemaHandler extends AbstractDataSourceHandler impleme
newCatalog
=
(
DBSCatalog
)
newInstance
;
}
}
DBSObject
schemaObject
;
if
(
newCatalog
==
null
)
{
schemaObject
=
rootContainer
.
getChild
(
monitor
,
newSchemaName
);
}
else
{
schemaObject
=
newCatalog
.
getChild
(
monitor
,
newSchemaName
);
}
if
(
schemaObject
instanceof
DBSSchema
)
{
newSchema
=
(
DBSSchema
)
schemaObject
;
DBSObject
schemaObject
=
null
;
if
(
newSchemaName
!=
null
)
{
if
(
newCatalog
==
null
)
{
schemaObject
=
rootContainer
.
getChild
(
monitor
,
newSchemaName
);
}
else
{
schemaObject
=
newCatalog
.
getChild
(
monitor
,
newSchemaName
);
}
if
(
schemaObject
instanceof
DBSSchema
)
{
newSchema
=
(
DBSSchema
)
schemaObject
;
}
}
boolean
changeCatalog
=
!
CommonUtils
.
equalObjects
(
curInstanceName
,
newInstanceName
);
...
...
@@ -388,7 +390,10 @@ public class SelectActiveSchemaHandler extends AbstractDataSourceHandler impleme
// Nothing can be changed
objectContainer
=
null
;
}
defObject
=
contextDefaults
.
getDefaultSchema
();
DBSSchema
defaultSchema
=
contextDefaults
.
getDefaultSchema
();
if
(
defaultSchema
!=
null
)
{
defObject
=
defaultSchema
;
}
}
else
{
// Default object can be object container + object selector (e.g. in PG)
objectSelector
=
DBUtils
.
getAdapter
(
DBSObjectSelector
.
class
,
defObject
);
...
...
@@ -453,16 +458,22 @@ public class SelectActiveSchemaHandler extends AbstractDataSourceHandler impleme
for
(
DBNDatabaseNode
node
:
databaseListReader
.
nodeList
)
{
menuItems
.
add
(
new
ActionContributionItem
(
new
Action
(
node
.
getName
(),
Action
.
AS_CHECK_BOX
)
{
private
final
DBSObject
object
=
node
.
getObject
();
{
setImageDescriptor
(
DBeaverIcons
.
getImageDescriptor
(
node
.
getNodeIcon
()));
}
@Override
public
boolean
isChecked
()
{
return
ArrayUtils
.
contains
(
finalDefObjects
,
node
.
getObject
()
);
return
ArrayUtils
.
contains
(
finalDefObjects
,
object
);
}
@Override
public
void
run
()
{
changeDataBaseSelection
(
dataSourceContainer
,
executionContext
,
databaseListReader
.
currentDatabaseInstanceName
,
databaseListReader
.
currentDatabaseInstanceName
,
node
.
getNodeName
());
changeDataBaseSelection
(
dataSourceContainer
,
executionContext
,
databaseListReader
.
currentDatabaseInstanceName
,
(
object
instanceof
DBSCatalog
?
object
.
getName
()
:
databaseListReader
.
currentDatabaseInstanceName
),
(
object
instanceof
DBSSchema
?
node
.
getNodeName
()
:
null
));
}
}
));
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录