• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2014 Google Inc.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.google.inject.testing.fieldbinder;
18 
19 import static java.lang.annotation.ElementType.FIELD;
20 import static java.lang.annotation.RetentionPolicy.RUNTIME;
21 
22 import java.lang.annotation.Retention;
23 import java.lang.annotation.Target;
24 
25 /**
26  * Annotation used by {@link BoundFieldModule} to indicate that a field should be bound to its
27  * value using Guice.
28  *
29  * @see BoundFieldModule
30  * @author eatnumber1@google.com (Russ Harmon)
31  */
32 @Retention(RUNTIME)
33 @Target({FIELD})
34 public @interface Bind {
35   /**
36    * If specified, {@link BoundFieldModule} will bind the annotated field's value to this type,
37    * rather than to the field's actual type.
38    */
to()39   Class<?> to() default Bind.class;
40 
41   /**
42    * If true, {@link BoundFieldModule} will delay retrieving the field's value until injection time
43    * rather than eagerly fetching it at configure time.
44    *
45    * <p>This option is not supported with Provider valued fields.
46    */
lazy()47   boolean lazy() default false;
48 }
49