From 4027b929c248a7c0a3df5b445b597637649b33b6 Mon Sep 17 00:00:00 2001 From: ribeaudc <ribeaudc> Date: Wed, 27 Jun 2007 08:30:12 +0000 Subject: [PATCH] add: - annotations for concurrency SVN: 695 --- .../cisd/common/annotation/GuardedBy.java | 47 +++++++++++++++++++ .../cisd/common/annotation/ThreadSafe.java | 36 ++++++++++++++ 2 files changed, 83 insertions(+) create mode 100644 common/source/java/ch/systemsx/cisd/common/annotation/GuardedBy.java create mode 100644 common/source/java/ch/systemsx/cisd/common/annotation/ThreadSafe.java diff --git a/common/source/java/ch/systemsx/cisd/common/annotation/GuardedBy.java b/common/source/java/ch/systemsx/cisd/common/annotation/GuardedBy.java new file mode 100644 index 00000000000..bbf463f9834 --- /dev/null +++ b/common/source/java/ch/systemsx/cisd/common/annotation/GuardedBy.java @@ -0,0 +1,47 @@ +/* + * Copyright 2007 ETH Zuerich, CISD + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package ch.systemsx.cisd.common.annotation; + +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; + +/** + * The field or method to which this annotation is applied can only be accessed when holding a particular lock, which + * may be a built-in (synchronization) lock, or may be an explicit java.util.concurrent.Lock. The argument determines + * which lock guards the annotated field or method: + * <ul> + * <li><code>this</code>: The intrinsic lock of the object in whose class the field is defined.</li> + * <li><code>class-name.this</code>: For inner classes, it may be necessary to disambiguate 'this'; the + * <em>class-name.this</em> designation allows you to specify which 'this' reference is intended</li> + * <li><code>itself</code>: For reference fields only; the object to which the field refers.</li> + * <li><code>field-name</code>: The lock object is referenced by the (instance or static) field specified by + * <em>field-name</em>.</li> + * <li><code>class-name.field-name</code>: The lock object is reference by the static field specified by + * <em>class-name.field-name</em>.</li> + * <li><code>method-name()</code> : The lock object is returned by calling the named nil-ary method. </li> + * <li> <code>class-name.class</code> : The Class object for the specified class should be used as the lock object. + * </li> + */ +@Target( + { ElementType.FIELD, ElementType.METHOD }) +@Retention(RetentionPolicy.RUNTIME) +public @interface GuardedBy +{ + String value(); +} diff --git a/common/source/java/ch/systemsx/cisd/common/annotation/ThreadSafe.java b/common/source/java/ch/systemsx/cisd/common/annotation/ThreadSafe.java new file mode 100644 index 00000000000..adb33564679 --- /dev/null +++ b/common/source/java/ch/systemsx/cisd/common/annotation/ThreadSafe.java @@ -0,0 +1,36 @@ +/* + * Copyright 2007 ETH Zuerich, CISD + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package ch.systemsx.cisd.common.annotation; + +import java.lang.annotation.Documented; +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; + +/** + * The class to which this annotation is applied is thread-safe. This means that no sequences of accesses (reads and + * writes to public fields, calls to public methods) may put the object into an invalid state, regardless of the + * interleaving of those actions by the runtime, and without requiring any additional synchronization or coordination on + * the part of the caller. + */ +@Documented +@Target(ElementType.TYPE) +@Retention(RetentionPolicy.RUNTIME) +public @interface ThreadSafe +{ +} -- GitLab