You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

ValueProvider.java 1.8KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * Copyright 2000-2016 Vaadin Ltd.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License"); you may not
  5. * use this file except in compliance with the License. You may obtain a copy of
  6. * 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, WITHOUT
  12. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  13. * License for the specific language governing permissions and limitations under
  14. * the License.
  15. */
  16. package com.vaadin.data;
  17. import com.vaadin.server.SerializableFunction;
  18. /**
  19. * A callback interface for providing values from a given source.
  20. * <p>
  21. * For example this interface can be implemented to simply extract a value with
  22. * a getter, or to create a composite value based on the fields of the source
  23. * object.
  24. *
  25. * @author Vaadin Ltd.
  26. * @since 8.0
  27. *
  28. * @param <SOURCE>
  29. * the type of the object used to provide the value
  30. * @param <TARGET>
  31. * the type of the provided value
  32. */
  33. @FunctionalInterface
  34. public interface ValueProvider<SOURCE, TARGET>
  35. extends SerializableFunction<SOURCE, TARGET> {
  36. /**
  37. * Returns a value provider that always returns its input argument.
  38. *
  39. * @param <T>
  40. * the type of the input and output objects to the function
  41. * @return a function that always returns its input argument
  42. */
  43. public static <T> ValueProvider<T, T> identity() {
  44. return t -> t;
  45. }
  46. /**
  47. * Provides a value from the given source object.
  48. *
  49. * @param source
  50. * the source to retrieve the value from
  51. * @return the value provided by the source
  52. */
  53. @Override
  54. public TARGET apply(SOURCE source);
  55. }