/* @VaadinApache2LicenseForJavaFiles@ */ package com.vaadin.terminal; import java.io.Serializable; import com.vaadin.Application; /** * This interface must be implemented by classes wishing to provide Application * resources. *

* ApplicationResource are a set of named resources (pictures, * sounds, etc) associated with some specific application. Having named * application resources provides a convenient method for having inter-theme * common resources for an application. *

* * @author Vaadin Ltd. * @version * @VERSION@ * @since 3.0 */ public interface ApplicationResource extends Resource, Serializable { /** * Default cache time. */ public static final long DEFAULT_CACHETIME = 1000 * 60 * 60 * 24; /** * Gets resource as stream. */ public DownloadStream getStream(); /** * Gets the application of the resource. */ public Application getApplication(); /** * Gets the virtual filename for this resource. * * @return the file name associated to this resource. */ public String getFilename(); /** * Gets the length of cache expiration time. * *

* This gives the adapter the possibility cache streams sent to the client. * The caching may be made in adapter or at the client if the client * supports caching. Default is DEFAULT_CACHETIME. *

* * @return Cache time in milliseconds */ public long getCacheTime(); /** * Gets the size of the download buffer used for this resource. * *

* If the buffer size is 0, the buffer size is decided by the terminal * adapter. The default value is 0. *

* * @return int the size of the buffer in bytes. */ public int getBufferSize(); }