xapi.annotation.model.Persistent Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of xapi-dev Show documentation
Show all versions of xapi-dev Show documentation
Everything needed to run a comprehensive dev environment.
Just type X_ and pick a service from autocomplete;
new dev modules will be added as they are built.
The only dev service not included in the uber jar is xapi-dev-maven,
as it includes all runtime dependencies of maven, adding ~4 seconds to build time,
and 6 megabytes to the final output jar size (without xapi-dev-maven, it's ~1MB).
The newest version!
package xapi.annotation.model;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
*
*
* @author James X. Nelson ([email protected])
*
*/
@Retention(RetentionPolicy.RUNTIME)
@Target(value= {ElementType.METHOD})
public @interface Persistent {
/**
* @return true if a given field is patchable;
* meaning that it will only be serialized to a server if the value has changed.
*
* A patch operation requires an etag request to summarize whether the receiving party
* is already aware of the current variable's value or not.
*
* Setting to false will cause the value to be serialized upon every request.
*
* Note that patching is not currently supported.
*/
boolean patchable() default false;
PersistenceStrategy strategy() default PersistenceStrategy.Ram;
}