Loadable.java

  1. /*
  2.  * #%L
  3.  * *********************************************************************************************************************
  4.  *
  5.  * blueHour
  6.  * http://bluehour.tidalwave.it - git clone git@bitbucket.org:tidalwave/bluehour-src.git
  7.  * %%
  8.  * Copyright (C) 2013 - 2023 Tidalwave s.a.s. (http://tidalwave.it)
  9.  * %%
  10.  * *********************************************************************************************************************
  11.  *
  12.  * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
  13.  * the License. You may obtain a copy of the License at
  14.  *
  15.  *     http://www.apache.org/licenses/LICENSE-2.0
  16.  *
  17.  * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
  18.  * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the License for the
  19.  * specific language governing permissions and limitations under the License.
  20.  *
  21.  * *********************************************************************************************************************
  22.  *
  23.  *
  24.  * *********************************************************************************************************************
  25.  * #L%
  26.  */
  27. package it.tidalwave.accounting.role;

  28. import java.io.IOException;

  29. /***********************************************************************************************************************
  30.  *
  31.  * A role which provides loading from a default source.
  32.  *
  33.  * @stereotype Role
  34.  *
  35.  * @author  Fabrizio Giudici
  36.  *
  37.  **********************************************************************************************************************/
  38. public interface Loadable
  39.   {
  40.     public static final Class<Loadable> _Loadable_ = Loadable.class;
  41.    
  42.     /*******************************************************************************************************************
  43.      *
  44.      * Load from a default source.
  45.      *
  46.      * @return  the loaded object
  47.      * @throws  IOException         in case of error
  48.      *
  49.      ******************************************************************************************************************/
  50.     public <T> T load()
  51.       throws IOException;
  52.   }