javauis/eswt_qt/com.nokia.swt.extensions/extensions/org/eclipse/swt/internal/extension/Toolkit.java
author hgs
Mon, 04 Oct 2010 11:29:25 +0300
changeset 78 71ad690e91f5
permissions -rw-r--r--
v2.2.17_1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
78
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
     1
/*******************************************************************************
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
     2
 * Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
     3
 * All rights reserved. This program and the accompanying materials
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
     4
 * are made available under the terms of the Eclipse Public License v1.0
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
     5
 * which accompanies this distribution, and is available at
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
     6
 * http://www.eclipse.org/legal/epl-v10.html
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
     7
 *
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
     8
 * Contributors:
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
     9
 *     Nokia Corporation - initial implementation
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    10
 *******************************************************************************/
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    11
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    12
package org.eclipse.swt.internal.extension;
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    13
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    14
import org.eclipse.swt.internal.qt.EventLoop;
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    15
import org.eclipse.swt.widgets.Display;
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    16
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    17
/**
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    18
 * This class enables eSWT UI services to be used independently of the 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    19
 * application's UI life-cycle in the implementation of the APIs. I.e. without 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    20
 * having to know if the application has created a UI toolkit yet, if it has 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    21
 * already destroyed it, or if it will ever create it. 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    22
 * <p>
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    23
 * This is achieved by creating an 'internal' instance of the eSWT Display 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    24
 * class. I.e. an instance that is not revealed to the application but is only 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    25
 * used internally within the platform implementation. The application can 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    26
 * create the actual 'public' Display instance. Thus there can be two Display 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    27
 * objects but there's always only one set of UI resources such as  the native 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    28
 * application, UI thread, native widgets, etc. These same resources are used 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    29
 * by both the Displays. 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    30
 * <p>
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    31
 * The users of the internal Display instance must take into account that 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    32
 * the public eSWT APIs can never provide references to the internal Display 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    33
 * instance. This has the implication that any other means of obtaining 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    34
 * the Display besides the methods of this class will always use a reference 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    35
 * to the public Display instance or null if it doesn't exist. E.g. 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    36
 * Display.getCurrent() or Display.getDefault() can't be used to obtain the 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    37
 * internal Display instance because they will return null if the application 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    38
 * hasn't explicitly created the public Display instance. 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    39
 * 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    40
 * @see ApplicationUI
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    41
 */
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    42
final public class Toolkit {
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    43
    
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    44
    private static Display internalDisplay;
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    45
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    46
    /**
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    47
     * Returns an object reference to the internal Display instance. There's 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    48
     * only one internal Display object in the process. The caller does not own 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    49
     * the Display and must not dispose it. 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    50
     * <p>
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    51
     * The returned Display shares the UI resources in the process with the
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    52
     * possibly existing public Display instance owned by the application. The
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    53
     * UI thread and the event loop maybe under control of the application.
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    54
     * <p>
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    55
     * This method is thread safe. 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    56
     * 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    57
     * @return The internal Display instance
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    58
     * 
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    59
     * @throws RuntimeException
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    60
     *             If the UI creation has failed and the Display can't be
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    61
     *             obtained.
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    62
     */
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    63
    static public synchronized Display getInternalDisplay() {
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    64
        if(internalDisplay == null) {
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    65
            internalDisplay = EventLoop.getInternalDisplay();
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    66
        }
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    67
        return internalDisplay;
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    68
    }
71ad690e91f5 v2.2.17_1
hgs
parents:
diff changeset
    69
}