Class ElementSource
- java.lang.Object
-
- com.google.inject.spi.ElementSource
-
public final class ElementSource extends Object
Contains information about where and how anelementwas bound.The
declaring sourcerefers to a location in source code that defines the Guiceelement. For example, if the element is created from a method annotated by @Provides, the declaring source of element would be the method itself.The
getStackTrace()refers to the sequence of calls ends at one ofBinderbindXXX()methods and eventually defines the element. Note thatgetStackTrace()listsStackTraceElementsin reverse chronological order. The first element (index zero) is the last method call and the last element is the first method invocation. By default, the stack trace is not collected. The default behavior can be changed by setting theguice_include_stack_tracesflag value. The value can be eitherOFF,ONLY_FOR_DECLARING_SOURCEorCOMPLETE. Note that collecting stack traces for every binding can cause a performance hit when the injector is created.The sequence of class names of
modulesinvolved in the element creation can be retrieved bygetModuleClassNames(). Similar togetStackTrace(), the order is reverse chronological. The first module (index 0) is the module that installs theelement. The last module is the root module.In order to support the cases where a Guice
elementis created from another Guiceelement(original) (e.g., byElement.applyTo(com.google.inject.Binder)), it also provides a reference to the original element source (getOriginalElementSource()).- Since:
- 4.0
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description ObjectgetDeclaringSource()Returns a single location in source code that defines the element.List<String>getModuleClassNames()Returns the class names of modules involved in creating thisElement.List<Integer>getModuleConfigurePositionsInStackTrace()Returns the position ofconfigure(Binder)method call in thestack tracefor modules that their classes returned bygetModuleClassNames().ElementSourcegetOriginalElementSource()Returns theElementSourceof the element this was created or copied from.StackTraceElement[]getStackTrace()Returns the sequence of method calls that ends at one ofBinderbindXXX()methods and eventually defines the element.StringtoString()ReturnsgetDeclaringSource().toString()value.
-
-
-
Method Detail
-
getOriginalElementSource
public ElementSource getOriginalElementSource()
Returns theElementSourceof the element this was created or copied from. If this was not created or copied from another element, returnsnull.
-
getDeclaringSource
public Object getDeclaringSource()
Returns a single location in source code that defines the element. It can be any object such asConstructor,Method,Field,StackTraceElement, etc. For example, if the element is created from a method annotated by @Provides, the declaring source of element would be the method itself.
-
getModuleClassNames
public List<String> getModuleClassNames()
Returns the class names of modules involved in creating thisElement. The first element (index 0) is the class name of module that defined the element, and the last element is the class name of root module.
-
getModuleConfigurePositionsInStackTrace
public List<Integer> getModuleConfigurePositionsInStackTrace()
Returns the position ofconfigure(Binder)method call in thestack tracefor modules that their classes returned bygetModuleClassNames(). For example, if the stack trace looks like the following:Binder.bind()ModuleTwo.configure()Binder.install()ModuleOne.configure()- {@code theRest().
1 and 3 are returned.
In the cases where stack trace is not available (i.e., the stack trace was not collected), it returns -1 for all module positions.
-
getStackTrace
public StackTraceElement[] getStackTrace()
Returns the sequence of method calls that ends at one ofBinderbindXXX()methods and eventually defines the element. Note thatgetStackTrace()listsStackTraceElementsin reverse chronological order. The first element (index zero) is the last method call and the last element is the first method invocation. In the cases where stack trace is not available (i.e.,the stack trace was not collected), it returns an empty array.
-
-