]> gerrit.simantics Code Review - simantics/platform.git/blob - bundles/org.simantics.diagram/src/org/simantics/diagram/internal/DebugPolicy.java
Migrated source code from Simantics SVN
[simantics/platform.git] / bundles / org.simantics.diagram / src / org / simantics / diagram / internal / DebugPolicy.java
1 /*******************************************************************************\r
2  * Copyright (c) 2007, 2010 Association for Decentralized Information Management\r
3  * in Industry THTH ry.\r
4  * All rights reserved. This program and the accompanying materials\r
5  * are made available under the terms of the Eclipse Public License v1.0\r
6  * which accompanies this distribution, and is available at\r
7  * http://www.eclipse.org/legal/epl-v10.html\r
8  *\r
9  * Contributors:\r
10  *     VTT Technical Research Centre of Finland - initial API and implementation\r
11  *******************************************************************************/\r
12 package org.simantics.diagram.internal;\r
13 \r
14 import org.eclipse.core.runtime.Platform;\r
15 import org.simantics.diagram.adapter.GraphToDiagramSynchronizer;\r
16 import org.simantics.diagram.synchronization.IModifiableSynchronizationContext;\r
17 \r
18 /**\r
19  * @author Tuukka Lehtonen\r
20  */\r
21 public final class DebugPolicy {\r
22 \r
23     public static boolean DEBUG = false;\r
24 \r
25     public static boolean DEBUG_GRAPH_WRITEBACK               = false;\r
26     public static boolean DEBUG_GRAPH_WRITEBACK_MODIFICATION  = false;\r
27 \r
28     public static boolean DEBUG_TERMINAL_SEARCH               = false;\r
29 \r
30     public static boolean DEBUG_LOAD                          = false;\r
31     public static boolean DEBUG_NODE_LOAD                     = false;\r
32     public static boolean DEBUG_CONNECTION_LOAD               = false;\r
33     public static boolean DEBUG_EDGE_LOAD                     = false;\r
34     public static boolean DEBUG_CONNECTION_VISUALS_LOAD       = false;\r
35     public static boolean DEBUG_TRANSFORM_LOAD                = false;\r
36 \r
37     public static double  DETERMINANT_LIMIT_HIGH              = 1e24;\r
38     public static double  DETERMINANT_LIMIT_LOW               = 1e-24;\r
39     public static double  TRANSLATION_LIMIT_HIGH              = 1e32;\r
40 \r
41     public static boolean DEBUG_EDGE_LISTENER                 = false;\r
42 \r
43     public static boolean DEBUG_GENERAL_ELEMENT_UPDATE        = false;\r
44     public static boolean DEBUG_GENERAL_ELEMENT_UPDATE_DETAIL = false;\r
45     public static boolean DEBUG_GRAPH_UPDATE                  = false;\r
46     public static boolean DEBUG_DIAGRAM_UPDATE                = false;\r
47     public static boolean DEBUG_DIAGRAM_UPDATE_DETAIL         = false;\r
48     public static boolean DEBUG_NODE_UPDATE                   = false;\r
49     public static boolean DEBUG_CONNECTION_UPDATE             = false;\r
50     public static boolean DEBUG_EDGE_UPDATE                   = false;\r
51 \r
52     public static boolean DEBUG_LISTENER_BASE                 = false;\r
53     public static boolean DEBUG_DIAGRAM_LISTENER              = false;\r
54     public static boolean DEBUG_NODE_LISTENER                 = false;\r
55     public static boolean DEBUG_CONNECTION_LISTENER           = false;\r
56 \r
57     /**\r
58      * Enables tracing of\r
59      * {@link IModifiableSynchronizationContext#set(org.simantics.utils.datastructures.hints.IHintContext.Key, Object)}\r
60      * operations.\r
61      */\r
62     public static boolean DEBUG_SYNC_CONTEXT                 = false;\r
63 \r
64     public static boolean DEBUG_STATE                        = false;\r
65     public static boolean DEBUG_MAPPING                      = false;\r
66     public static boolean DEBUG_ELEMENT_LIFECYCLE            = false;\r
67     public static boolean DEBUG_CONNECTION                   = false;\r
68 \r
69     public static boolean DEBUG_RELATIONSHIP                 = false;\r
70     public static boolean DEBUG_GET_RELATIONSHIP             = false;\r
71 \r
72     public static boolean DEBUG_LAYERS                       = false;\r
73 \r
74     public static boolean DEBUG_MUTATOR                      = false;\r
75     public static boolean DEBUG_MUTATOR_COMMIT               = false;\r
76 \r
77     public static boolean DEBUG_WRITE_TRANSACTIONS           = false;\r
78 \r
79     /**\r
80      * Enables default copy paste handler debug output.\r
81      */\r
82     public static boolean DEBUG_COPY_PASTE                   = false;\r
83 \r
84     /**\r
85      * This will disable all node/edge/diagram content query listeners from\r
86      * performing updates. Maybe useful for debugging since\r
87      * {@link GraphToDiagramSynchronizer} will only load the initial diagram\r
88      * contents and process updates to those elements, but will not process\r
89      * updates to the diagram structure.\r
90      */\r
91     public static boolean DISABLE_DIAGRAM_UPDATES            = false;\r
92 \r
93     /**\r
94      * Indicates whether certain performance timings are performed and the\r
95      * results printed out.\r
96      */\r
97     public static boolean PERFORM_TIMING                     = false;\r
98 \r
99     static {\r
100         if (Activator.getDefault().isDebugging()) {\r
101             DEBUG = true;\r
102             String sTrue = Boolean.TRUE.toString();\r
103 \r
104             DEBUG_GRAPH_WRITEBACK = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/graphWriteback")); //$NON-NLS-1$\r
105             DEBUG_GRAPH_WRITEBACK_MODIFICATION = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/graphWriteback/modifications")); //$NON-NLS-1$\r
106 \r
107             DEBUG_LOAD = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/load")); //$NON-NLS-1$\r
108             DEBUG_NODE_LOAD = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/load/node")); //$NON-NLS-1$\r
109             DEBUG_CONNECTION_LOAD = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/load/connection")); //$NON-NLS-1$\r
110             DEBUG_EDGE_LOAD = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/load/edge")); //$NON-NLS-1$\r
111             DEBUG_CONNECTION_VISUALS_LOAD = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/load/connectionVisuals")); //$NON-NLS-1$\r
112             DEBUG_TERMINAL_SEARCH = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/load/terminalSearch")); //$NON-NLS-1$\r
113             DEBUG_TRANSFORM_LOAD = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/load/transform")); //$NON-NLS-1$\r
114             DETERMINANT_LIMIT_HIGH = parseDouble(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/load/transform/determinanLimitHigh"), DETERMINANT_LIMIT_HIGH); //$NON-NLS-1$\r
115             DETERMINANT_LIMIT_LOW = parseDouble(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/load/transform/determinantLimitLow"), DETERMINANT_LIMIT_LOW); //$NON-NLS-1$\r
116             TRANSLATION_LIMIT_HIGH = parseDouble(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/load/transform/translationLimitHigh"), TRANSLATION_LIMIT_HIGH); //$NON-NLS-1$\r
117 \r
118             DEBUG_GENERAL_ELEMENT_UPDATE = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/generalElementUpdate")); //$NON-NLS-1$\r
119             DEBUG_GENERAL_ELEMENT_UPDATE_DETAIL = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/generalElementUpdate/detail")); //$NON-NLS-1$\r
120 \r
121             DEBUG_GRAPH_UPDATE = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/update")); //$NON-NLS-1$\r
122             DEBUG_DIAGRAM_UPDATE = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/update/diagram")); //$NON-NLS-1$\r
123             DEBUG_DIAGRAM_UPDATE_DETAIL = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/update/diagram/detail")); //$NON-NLS-1$\r
124             DEBUG_NODE_UPDATE = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/update/node")); //$NON-NLS-1$\r
125             DEBUG_CONNECTION_UPDATE = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/update/connection")); //$NON-NLS-1$\r
126             DEBUG_EDGE_UPDATE = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/update/edge")); //$NON-NLS-1$\r
127 \r
128             DEBUG_LISTENER_BASE = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/listener")); //$NON-NLS-1$\r
129             DEBUG_DIAGRAM_LISTENER = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/listener/diagram")); //$NON-NLS-1$\r
130             DEBUG_NODE_LISTENER = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/listener/node")); //$NON-NLS-1$\r
131             DEBUG_CONNECTION_LISTENER = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/listener/connection")); //$NON-NLS-1$\r
132             DEBUG_EDGE_LISTENER = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/listener/edge")); //$NON-NLS-1$\r
133 \r
134             DEBUG_SYNC_CONTEXT = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/context")); //$NON-NLS-1$\r
135 \r
136             DEBUG_STATE = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/state")); //$NON-NLS-1$\r
137             DEBUG_MAPPING = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/mapping")); //$NON-NLS-1$\r
138             DEBUG_ELEMENT_LIFECYCLE = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/elementLifecycle")); //$NON-NLS-1$\r
139             DEBUG_CONNECTION = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/topology/connection")); //$NON-NLS-1$\r
140 \r
141             DEBUG_RELATIONSHIP = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/relationship")); //$NON-NLS-1$\r
142             DEBUG_GET_RELATIONSHIP = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/relationship/get")); //$NON-NLS-1$\r
143 \r
144             DEBUG_LAYERS = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/layers")); //$NON-NLS-1$\r
145 \r
146             DEBUG_MUTATOR = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/mutator")); //$NON-NLS-1$\r
147             DEBUG_MUTATOR_COMMIT = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/mutator/commit")); //$NON-NLS-1$\r
148 \r
149             DEBUG_WRITE_TRANSACTIONS = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/synchronizer/transactions/write")); //$NON-NLS-1$\r
150 \r
151             DEBUG_COPY_PASTE = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/debug/copyPaste")); //$NON-NLS-1$\r
152 \r
153             //--\r
154 \r
155             DISABLE_DIAGRAM_UPDATES = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/control/update/diagram/disable")); //$NON-NLS-1$\r
156 \r
157             //--\r
158 \r
159             PERFORM_TIMING = sTrue.equalsIgnoreCase(Platform.getDebugOption(Activator.PLUGIN_ID + "/perf/generalDiagramTiming")); //$NON-NLS-1$\r
160         }\r
161     }\r
162 \r
163     private static double parseDouble(String value, double defaultValue) {\r
164         if (value == null)\r
165             return defaultValue;\r
166         try {\r
167             return Double.parseDouble(value);\r
168         } catch (NumberFormatException e) {\r
169             return defaultValue;\r
170         }\r
171     }\r
172 \r
173 }\r