Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
FIY695
jenkins
提交
82ef72c0
J
jenkins
项目概览
FIY695
/
jenkins
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
jenkins
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
82ef72c0
编写于
11月 15, 2011
作者:
K
Kohsuke Kawaguchi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Expose Injector to the rest of the world
上级
09ef861c
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
133 addition
and
3 deletion
+133
-3
core/src/main/java/hudson/ExtensionFinder.java
core/src/main/java/hudson/ExtensionFinder.java
+13
-1
core/src/main/java/hudson/PluginManager.java
core/src/main/java/hudson/PluginManager.java
+0
-2
core/src/main/java/jenkins/ProxyInjector.java
core/src/main/java/jenkins/ProxyInjector.java
+120
-0
未找到文件。
core/src/main/java/hudson/ExtensionFinder.java
浏览文件 @
82ef72c0
...
...
@@ -40,6 +40,7 @@ import hudson.model.Descriptor;
import
hudson.model.Hudson
;
import
jenkins.ExtensionComponentSet
;
import
jenkins.ExtensionRefreshException
;
import
jenkins.ProxyInjector
;
import
jenkins.model.Jenkins
;
import
net.java.sezpoz.Index
;
import
net.java.sezpoz.IndexItem
;
...
...
@@ -183,6 +184,13 @@ public abstract class ExtensionFinder implements ExtensionPoint {
public
static
final
class
GuiceFinder
extends
AbstractGuiceFinder
<
Extension
>
{
public
GuiceFinder
()
{
super
(
Extension
.
class
);
// expose Injector via lookup mechanism for interop with non-Guice clients
Jenkins
.
getInstance
().
lookup
.
set
(
Injector
.
class
,
new
ProxyInjector
()
{
protected
Injector
resolve
()
{
return
getContainer
();
}
});
}
@Override
...
...
@@ -207,7 +215,7 @@ public abstract class ExtensionFinder implements ExtensionPoint {
* a child container to house newly discovered components. This field points to the
* youngest such container.
*/
private
Injector
container
;
private
volatile
Injector
container
;
/**
* Sezpoz index we are currently using in {@link #container} (and its ancestors.)
...
...
@@ -242,6 +250,10 @@ public abstract class ExtensionFinder implements ExtensionPoint {
}
}
public
Injector
getContainer
()
{
return
container
;
}
/**
* The basic idea is:
*
...
...
core/src/main/java/hudson/PluginManager.java
浏览文件 @
82ef72c0
...
...
@@ -282,8 +282,6 @@ public abstract class PluginManager extends AbstractModelObject {
Jenkins
.
getInstance
().
lookup
.
set
(
PluginInstanceStore
.
class
,
new
PluginInstanceStore
());
TaskGraphBuilder
g
=
new
TaskGraphBuilder
();
Jenkins
.
getInstance
().
lookup
.
set
(
Injector
.
class
,
Guice
.
createInjector
());
// schedule execution of loading plugins
for
(
final
PluginWrapper
p
:
activePlugins
.
toArray
(
new
PluginWrapper
[
activePlugins
.
size
()]))
{
g
.
followedBy
().
notFatal
().
attains
(
PLUGINS_PREPARED
).
add
(
"Loading plugin "
+
p
.
getShortName
(),
new
Executable
()
{
...
...
core/src/main/java/jenkins/ProxyInjector.java
0 → 100644
浏览文件 @
82ef72c0
/*
* The MIT License
*
* Copyright (c) 2011, CloudBees, Inc.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
package
jenkins
;
import
com.google.inject.Binding
;
import
com.google.inject.Injector
;
import
com.google.inject.Key
;
import
com.google.inject.MembersInjector
;
import
com.google.inject.Module
;
import
com.google.inject.Provider
;
import
com.google.inject.Scope
;
import
com.google.inject.TypeLiteral
;
import
com.google.inject.spi.TypeConverterBinding
;
import
java.lang.annotation.Annotation
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Set
;
/**
* {@link Injector} that delegates to another one.
*
* @author Kohsuke Kawaguchi
*/
public
abstract
class
ProxyInjector
implements
Injector
{
protected
abstract
Injector
resolve
();
public
void
injectMembers
(
Object
instance
)
{
resolve
().
injectMembers
(
instance
);
}
public
<
T
>
MembersInjector
<
T
>
getMembersInjector
(
TypeLiteral
<
T
>
typeLiteral
)
{
return
resolve
().
getMembersInjector
(
typeLiteral
);
}
public
<
T
>
MembersInjector
<
T
>
getMembersInjector
(
Class
<
T
>
type
)
{
return
resolve
().
getMembersInjector
(
type
);
}
public
Map
<
Key
<?>,
Binding
<?>>
getBindings
()
{
return
resolve
().
getBindings
();
}
public
Map
<
Key
<?>,
Binding
<?>>
getAllBindings
()
{
return
resolve
().
getAllBindings
();
}
public
<
T
>
Binding
<
T
>
getBinding
(
Key
<
T
>
key
)
{
return
resolve
().
getBinding
(
key
);
}
public
<
T
>
Binding
<
T
>
getBinding
(
Class
<
T
>
type
)
{
return
resolve
().
getBinding
(
type
);
}
public
<
T
>
Binding
<
T
>
getExistingBinding
(
Key
<
T
>
key
)
{
return
resolve
().
getExistingBinding
(
key
);
}
public
<
T
>
List
<
Binding
<
T
>>
findBindingsByType
(
TypeLiteral
<
T
>
type
)
{
return
resolve
().
findBindingsByType
(
type
);
}
public
<
T
>
Provider
<
T
>
getProvider
(
Key
<
T
>
key
)
{
return
resolve
().
getProvider
(
key
);
}
public
<
T
>
Provider
<
T
>
getProvider
(
Class
<
T
>
type
)
{
return
resolve
().
getProvider
(
type
);
}
public
<
T
>
T
getInstance
(
Key
<
T
>
key
)
{
return
resolve
().
getInstance
(
key
);
}
public
<
T
>
T
getInstance
(
Class
<
T
>
type
)
{
return
resolve
().
getInstance
(
type
);
}
public
Injector
getParent
()
{
return
resolve
().
getParent
();
}
public
Injector
createChildInjector
(
Iterable
<?
extends
Module
>
modules
)
{
return
resolve
().
createChildInjector
(
modules
);
}
public
Injector
createChildInjector
(
Module
...
modules
)
{
return
resolve
().
createChildInjector
(
modules
);
}
public
Map
<
Class
<?
extends
Annotation
>,
Scope
>
getScopeBindings
()
{
return
resolve
().
getScopeBindings
();
}
public
Set
<
TypeConverterBinding
>
getTypeConverterBindings
()
{
return
resolve
().
getTypeConverterBindings
();
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录