Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
a58df2e4
D
dbeaver
项目概览
suliangchun
/
dbeaver
与 Fork 源项目一致
从无法访问的项目Fork
通知
3
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,发现更多精彩内容 >>
提交
a58df2e4
编写于
4月 16, 2017
作者:
S
Serge Rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Stats presentation UI fix.
Dynamic sel provider fix (NPE during editor init).
上级
c6a26529
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
29 addition
and
19 deletion
+29
-19
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/controls/resultset/ResultSetPanelDescriptor.java
...eaver/ui/controls/resultset/ResultSetPanelDescriptor.java
+3
-4
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/controls/resultset/ResultSetPresentationRegistry.java
.../ui/controls/resultset/ResultSetPresentationRegistry.java
+2
-2
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/controls/resultset/ResultSetViewer.java
.../jkiss/dbeaver/ui/controls/resultset/ResultSetViewer.java
+6
-1
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/editors/sql/SQLEditor.java
....core/src/org/jkiss/dbeaver/ui/editors/sql/SQLEditor.java
+16
-12
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/editors/text/BaseTextEditor.java
...src/org/jkiss/dbeaver/ui/editors/text/BaseTextEditor.java
+2
-0
未找到文件。
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/controls/resultset/ResultSetPanelDescriptor.java
浏览文件 @
a58df2e4
...
@@ -98,7 +98,7 @@ public class ResultSetPanelDescriptor extends AbstractContextDescriptor {
...
@@ -98,7 +98,7 @@ public class ResultSetPanelDescriptor extends AbstractContextDescriptor {
return
showByDefault
;
return
showByDefault
;
}
}
public
boolean
supportedBy
(
DBPDataSource
dataSource
,
ResultSetPresentationDescriptor
presentation
)
{
public
boolean
supportedBy
(
DBPDataSource
dataSource
,
String
presentationId
,
IResultSetPresentation
.
PresentationType
presentationType
)
{
if
(!
supportedDataSources
.
isEmpty
())
{
if
(!
supportedDataSources
.
isEmpty
())
{
if
(
dataSource
==
null
)
{
if
(
dataSource
==
null
)
{
return
false
;
return
false
;
...
@@ -108,13 +108,12 @@ public class ResultSetPanelDescriptor extends AbstractContextDescriptor {
...
@@ -108,13 +108,12 @@ public class ResultSetPanelDescriptor extends AbstractContextDescriptor {
return
false
;
return
false
;
}
}
}
}
//if (.getId())
if
(
supportedPresentations
.
isEmpty
()
&&
supportedPresentationTypes
.
isEmpty
())
{
if
(
supportedPresentations
.
isEmpty
()
&&
supportedPresentationTypes
.
isEmpty
())
{
return
true
;
return
true
;
}
}
return
return
supportedPresentations
.
contains
(
presentation
.
getId
(
))
||
(
presentationId
!=
null
&&
supportedPresentations
.
contains
(
presentationId
))
||
supportedPresentationTypes
.
contains
(
presentation
.
getPresentationType
(
));
(
presentationType
!=
null
&&
supportedPresentationTypes
.
contains
(
presentationType
));
}
}
public
IResultSetPanel
createInstance
()
throws
DBException
{
public
IResultSetPanel
createInstance
()
throws
DBException
{
...
...
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/controls/resultset/ResultSetPresentationRegistry.java
浏览文件 @
a58df2e4
...
@@ -110,10 +110,10 @@ public class ResultSetPresentationRegistry {
...
@@ -110,10 +110,10 @@ public class ResultSetPresentationRegistry {
return
panels
;
return
panels
;
}
}
public
List
<
ResultSetPanelDescriptor
>
getSupportedPanels
(
DBPDataSource
dataSource
,
ResultSetPresentationDescriptor
presentation
)
{
public
List
<
ResultSetPanelDescriptor
>
getSupportedPanels
(
DBPDataSource
dataSource
,
String
presentationId
,
IResultSetPresentation
.
PresentationType
presentationType
)
{
List
<
ResultSetPanelDescriptor
>
result
=
new
ArrayList
<>();
List
<
ResultSetPanelDescriptor
>
result
=
new
ArrayList
<>();
for
(
ResultSetPanelDescriptor
panel
:
panels
)
{
for
(
ResultSetPanelDescriptor
panel
:
panels
)
{
if
(
panel
.
supportedBy
(
dataSource
,
presentation
))
{
if
(
panel
.
supportedBy
(
dataSource
,
presentation
Id
,
presentationType
))
{
result
.
add
(
panel
);
result
.
add
(
panel
);
}
}
}
}
...
...
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/controls/resultset/ResultSetViewer.java
浏览文件 @
a58df2e4
...
@@ -518,7 +518,12 @@ public class ResultSetViewer extends Viewer
...
@@ -518,7 +518,12 @@ public class ResultSetViewer extends Viewer
availablePanels
.
clear
();
availablePanels
.
clear
();
activePanels
.
clear
();
activePanels
.
clear
();
if
(
activePresentationDescriptor
!=
null
)
{
if
(
activePresentationDescriptor
!=
null
)
{
availablePanels
.
addAll
(
ResultSetPresentationRegistry
.
getInstance
().
getSupportedPanels
(
getDataSource
(),
activePresentationDescriptor
));
availablePanels
.
addAll
(
ResultSetPresentationRegistry
.
getInstance
().
getSupportedPanels
(
getDataSource
(),
activePresentationDescriptor
.
getId
(),
activePresentationDescriptor
.
getPresentationType
()));
}
else
{
// Stats presentation
availablePanels
.
addAll
(
ResultSetPresentationRegistry
.
getInstance
().
getSupportedPanels
(
getDataSource
(),
null
,
IResultSetPresentation
.
PresentationType
.
COLUMNS
));
}
}
activePresentation
.
createPresentation
(
this
,
presentationPanel
);
activePresentation
.
createPresentation
(
this
,
presentationPanel
);
...
...
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/editors/sql/SQLEditor.java
浏览文件 @
a58df2e4
...
@@ -26,8 +26,7 @@ import org.eclipse.core.runtime.jobs.IJobChangeEvent;
...
@@ -26,8 +26,7 @@ import org.eclipse.core.runtime.jobs.IJobChangeEvent;
import
org.eclipse.core.runtime.jobs.Job
;
import
org.eclipse.core.runtime.jobs.Job
;
import
org.eclipse.core.runtime.jobs.JobChangeAdapter
;
import
org.eclipse.core.runtime.jobs.JobChangeAdapter
;
import
org.eclipse.jface.action.*
;
import
org.eclipse.jface.action.*
;
import
org.eclipse.jface.dialogs.*
;
import
org.eclipse.jface.dialogs.IDialogConstants
;
import
org.eclipse.jface.resource.JFaceResources
;
import
org.eclipse.jface.text.*
;
import
org.eclipse.jface.text.*
;
import
org.eclipse.jface.viewers.ISelectionProvider
;
import
org.eclipse.jface.viewers.ISelectionProvider
;
import
org.eclipse.jface.viewers.StructuredSelection
;
import
org.eclipse.jface.viewers.StructuredSelection
;
...
@@ -70,7 +69,6 @@ import org.jkiss.dbeaver.model.runtime.DBRProgressListener;
...
@@ -70,7 +69,6 @@ import org.jkiss.dbeaver.model.runtime.DBRProgressListener;
import
org.jkiss.dbeaver.model.runtime.DBRProgressMonitor
;
import
org.jkiss.dbeaver.model.runtime.DBRProgressMonitor
;
import
org.jkiss.dbeaver.model.runtime.DBRRunnableWithProgress
;
import
org.jkiss.dbeaver.model.runtime.DBRRunnableWithProgress
;
import
org.jkiss.dbeaver.model.sql.*
;
import
org.jkiss.dbeaver.model.sql.*
;
import
org.jkiss.dbeaver.model.sql.parser.SQLSemanticProcessor
;
import
org.jkiss.dbeaver.model.struct.DBSDataContainer
;
import
org.jkiss.dbeaver.model.struct.DBSDataContainer
;
import
org.jkiss.dbeaver.model.struct.DBSObject
;
import
org.jkiss.dbeaver.model.struct.DBSObject
;
import
org.jkiss.dbeaver.model.struct.DBSObjectSelector
;
import
org.jkiss.dbeaver.model.struct.DBSObjectSelector
;
...
@@ -363,7 +361,7 @@ public class SQLEditor extends SQLEditorBase implements
...
@@ -363,7 +361,7 @@ public class SQLEditor extends SQLEditorBase implements
private
class
OpenContextJob
extends
AbstractJob
{
private
class
OpenContextJob
extends
AbstractJob
{
private
final
DBPDataSource
dataSource
;
private
final
DBPDataSource
dataSource
;
private
Throwable
error
;
private
Throwable
error
;
protected
OpenContextJob
(
DBPDataSource
dataSource
)
{
OpenContextJob
(
DBPDataSource
dataSource
)
{
super
(
"Open connection to "
+
dataSource
.
getContainer
().
getName
());
super
(
"Open connection to "
+
dataSource
.
getContainer
().
getName
());
this
.
dataSource
=
dataSource
;
this
.
dataSource
=
dataSource
;
setUser
(
true
);
setUser
(
true
);
...
@@ -389,7 +387,7 @@ public class SQLEditor extends SQLEditorBase implements
...
@@ -389,7 +387,7 @@ public class SQLEditor extends SQLEditorBase implements
private
class
CloseContextJob
extends
AbstractJob
{
private
class
CloseContextJob
extends
AbstractJob
{
private
final
DBCExecutionContext
context
;
private
final
DBCExecutionContext
context
;
protected
CloseContextJob
(
DBCExecutionContext
context
)
{
CloseContextJob
(
DBCExecutionContext
context
)
{
super
(
"Close context "
+
context
.
getContextName
());
super
(
"Close context "
+
context
.
getContextName
());
this
.
context
=
context
;
this
.
context
=
context
;
setUser
(
true
);
setUser
(
true
);
...
@@ -1402,7 +1400,7 @@ public class SQLEditor extends SQLEditorBase implements
...
@@ -1402,7 +1400,7 @@ public class SQLEditor extends SQLEditorBase implements
}
}
@Nullable
@Nullable
p
ublic
ResultSetViewer
getActiveResultSetViewer
()
p
rivate
ResultSetViewer
getActiveResultSetViewer
()
{
{
if
(
curResultsContainer
!=
null
)
{
if
(
curResultsContainer
!=
null
)
{
return
curResultsContainer
.
getResultSetController
();
return
curResultsContainer
.
getResultSetController
();
...
@@ -1475,7 +1473,7 @@ public class SQLEditor extends SQLEditorBase implements
...
@@ -1475,7 +1473,7 @@ public class SQLEditor extends SQLEditorBase implements
private
final
List
<
QueryResultsContainer
>
resultContainers
=
new
ArrayList
<>();
private
final
List
<
QueryResultsContainer
>
resultContainers
=
new
ArrayList
<>();
private
DBDDataReceiver
curDataReceiver
=
null
;
private
DBDDataReceiver
curDataReceiver
=
null
;
public
QueryProcessor
()
{
QueryProcessor
()
{
// Create first (default) results provider
// Create first (default) results provider
queryProcessors
.
add
(
this
);
queryProcessors
.
add
(
this
);
createResultsProvider
(
0
);
createResultsProvider
(
0
);
...
@@ -1988,8 +1986,11 @@ public class SQLEditor extends SQLEditorBase implements
...
@@ -1988,8 +1986,11 @@ public class SQLEditor extends SQLEditorBase implements
DBeaverUI
.
syncExec
(
new
Runnable
()
{
DBeaverUI
.
syncExec
(
new
Runnable
()
{
@Override
@Override
public
void
run
()
{
public
void
run
()
{
topOffset
=
getTextViewer
().
getTopIndexStartOffset
();
TextViewer
textViewer
=
getTextViewer
();
visibleLength
=
getTextViewer
().
getBottomIndexEndOffset
()
-
topOffset
;
if
(
textViewer
!=
null
)
{
topOffset
=
textViewer
.
getTopIndexStartOffset
();
visibleLength
=
textViewer
.
getBottomIndexEndOffset
()
-
topOffset
;
}
}
}
});
});
if
(
scriptMode
)
{
if
(
scriptMode
)
{
...
@@ -2105,7 +2106,8 @@ public class SQLEditor extends SQLEditorBase implements
...
@@ -2105,7 +2106,8 @@ public class SQLEditor extends SQLEditorBase implements
@Override
@Override
public
IFindReplaceTarget
getTarget
()
{
public
IFindReplaceTarget
getTarget
()
{
ResultSetViewer
rsv
=
getActiveResultSetViewer
();
ResultSetViewer
rsv
=
getActiveResultSetViewer
();
boolean
focusInEditor
=
getTextViewer
().
getTextWidget
().
isFocusControl
();
TextViewer
textViewer
=
getTextViewer
();
boolean
focusInEditor
=
textViewer
!=
null
&&
textViewer
.
getTextWidget
().
isFocusControl
();
if
(!
focusInEditor
)
{
if
(!
focusInEditor
)
{
if
(
rsv
!=
null
&&
rsv
.
getActivePresentation
().
getControl
().
isFocusControl
())
{
if
(
rsv
!=
null
&&
rsv
.
getActivePresentation
().
getControl
().
isFocusControl
())
{
focusInEditor
=
false
;
focusInEditor
=
false
;
...
@@ -2119,8 +2121,10 @@ public class SQLEditor extends SQLEditorBase implements
...
@@ -2119,8 +2121,10 @@ public class SQLEditor extends SQLEditorBase implements
if
(
nested
!=
null
)
{
if
(
nested
!=
null
)
{
return
nested
;
return
nested
;
}
}
}
else
if
(
textViewer
!=
null
)
{
return
textViewer
.
getFindReplaceTarget
();
}
}
return
getTextViewer
().
getFindReplaceTarget
()
;
return
null
;
}
}
}
}
...
@@ -2228,7 +2232,7 @@ public class SQLEditor extends SQLEditorBase implements
...
@@ -2228,7 +2232,7 @@ public class SQLEditor extends SQLEditorBase implements
private
class
SaveJob
extends
AbstractJob
{
private
class
SaveJob
extends
AbstractJob
{
private
transient
Boolean
success
=
null
;
private
transient
Boolean
success
=
null
;
public
SaveJob
()
{
SaveJob
()
{
super
(
"Save '"
+
getPartName
()
+
"' data changes..."
);
super
(
"Save '"
+
getPartName
()
+
"' data changes..."
);
setUser
(
true
);
setUser
(
true
);
}
}
...
...
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/editors/text/BaseTextEditor.java
浏览文件 @
a58df2e4
...
@@ -197,11 +197,13 @@ public abstract class BaseTextEditor extends AbstractDecoratedTextEditor impleme
...
@@ -197,11 +197,13 @@ public abstract class BaseTextEditor extends AbstractDecoratedTextEditor impleme
}
}
}
}
@Nullable
public
TextViewer
getTextViewer
()
public
TextViewer
getTextViewer
()
{
{
return
(
TextViewer
)
getSourceViewer
();
return
(
TextViewer
)
getSourceViewer
();
}
}
@Nullable
public
SourceViewer
getViewer
()
public
SourceViewer
getViewer
()
{
{
return
(
SourceViewer
)
super
.
getSourceViewer
();
return
(
SourceViewer
)
super
.
getSourceViewer
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录