summaryrefslogtreecommitdiffstats
path: root/server/src
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2013-04-03 17:45:51 +0300
committerVaadin Code Review <review@vaadin.com>2013-04-03 17:05:57 +0000
commite97d8f42b64ab091b6bf1c4a1a5b130c3c29e26a (patch)
tree84ba98c024d0486acdb19583117421bf4960085d /server/src
parent134bc904a65c15849dcc9d2856dd4576ea2d4edc (diff)
downloadvaadin-framework-e97d8f42b64ab091b6bf1c4a1a5b130c3c29e26a.tar.gz
vaadin-framework-e97d8f42b64ab091b6bf1c4a1a5b130c3c29e26a.zip
Updated javadoc to mention runSafely in addition to the manual locking pattern
Change-Id: Ia0ddf6149641b8dc609c5c6e53ad569c5bc9c555
Diffstat (limited to 'server/src')
-rw-r--r--server/src/com/vaadin/server/VaadinSession.java25
1 files changed, 21 insertions, 4 deletions
diff --git a/server/src/com/vaadin/server/VaadinSession.java b/server/src/com/vaadin/server/VaadinSession.java
index 61a3cfb077..844b7ff674 100644
--- a/server/src/com/vaadin/server/VaadinSession.java
+++ b/server/src/com/vaadin/server/VaadinSession.java
@@ -761,9 +761,25 @@ public class VaadinSession implements HttpSessionBindingListener, Serializable {
/**
* Locks this session to protect its data from concurrent access. Accessing
* the UI state from outside the normal request handling should always lock
- * the session and unlock it when done. To ensure that the lock is always
- * released, you should typically wrap the code in a <code>try</code> block
- * and unlock the session in <code>finally</code>:
+ * the session and unlock it when done. The preferred way to ensure locking
+ * is done correctly is to wrap your code using
+ * {@link UI#runSafely(Runnable)} (or
+ * {@link VaadinSession#runSafely(Runnable)} if you are only touching the
+ * session and not any UI), e.g.:
+ *
+ * <pre>
+ * myUI.runSafely(new Runnable() {
+ * &#064;Override
+ * public void run() {
+ * // Here it is safe to update the UI.
+ * // UI.getCurrent can also be used
+ * myUI.getContent().setCaption(&quot;Changed safely&quot;);
+ * }
+ * });
+ * </pre>
+ *
+ * If you for whatever reason want to do locking manually, you should do it
+ * like:
*
* <pre>
* session.lock();
@@ -773,7 +789,7 @@ public class VaadinSession implements HttpSessionBindingListener, Serializable {
* session.unlock();
* }
* </pre>
- * <p>
+ *
* This method will block until the lock can be retrieved.
* <p>
* {@link #getLockInstance()} can be used if more control over the locking
@@ -781,6 +797,7 @@ public class VaadinSession implements HttpSessionBindingListener, Serializable {
*
* @see #unlock()
* @see #getLockInstance()
+ * @see #hasLock()
*/
public void lock() {
getLockInstance().lock();