File: pythonplugins.rst

package info (click to toggle)
tulip 3.7.0dfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 39,428 kB
  • sloc: cpp: 231,403; php: 11,023; python: 1,128; sh: 671; yacc: 522; makefile: 315; xml: 63; lex: 55
file content (426 lines) | stat: -rwxr-xr-x 19,043 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
.. py:currentmodule:: tulip

Writing Tulip plugins in Python
===============================

The Tulip Python bindings offer the possibility to write Tulip plugins in pure Python.
You can easily develop and test Python plugins from the Tulip GUI through the "Tulip plugin editor" tab
of the "Python Script view" (see :ref:`Using the bindings from the Tulip Software GUI <usingBindingsInTulipGUI>`).

Below is the list of plugins that can be implemented in Python :

	* General algorithms
	* Selection algorithms
	* Color algorithms
	* Metric algorithms
	* Integer algorithms
	* Layout algorithms
	* Size algorithms
	* Export modules
	* Import modules
	
Developing a plugin consists in writing a Python module (in a specific .py file) that contains the implementation 
of a Python class deriving from another one specific to the plugin type.
The plugin is then registered in the plugin database through the use of 
specific functions from the :mod:`tuliplugins` module (see :ref:`tulipplugins module API <tulippluginsref>`).
Once the plugin written and functional, you can copy the source file(s) to the following directory :
<tulip_install_dir>/lib/tulip/python and it will be automatically loaded at Tulip startup.
The remaining of this section illustrates how to write each type of plugin.

Writing a general algorithm in Python
--------------------------------------

A general algorithm must implement the :class:`tlp.Algorithm` interface as illustrated below::

	from tulip import *
	import tulipplugins
	
	class GeneralAlgorithmExample(tlp.Algorithm):
		def __init__(self, context):
			tlp.Algorithm.__init__(self, context)
			# you can add parameters to the plugin here through the following syntax
			# self.add<Type>Parameter("<paramName>", "<paramDoc>", "<paramDefaultValue>")
			# (see documentation of class tlp.WithParameter to see what types of parameters are supported)
	
		def check(self):
			# This method is called before applying the algorithm on the input graph.
			# You can perform some precondition checks here.
			# See comments in the run method to know how to access to the input graph.
			
			# Must return a tuple (boolean, string). First member indicates if the algorithm can be applied
			# and the second one can be used to provide an error message
			return (True, "Ok")
	
		def run(self):
			# This method is the entry point of the algorithm when it is called
			# and must contain its implementation.
			
			# The graph on which the algorithm is applied can be accessed through
			# the "graph" class attribute (see documentation of class tlp.Graph).
	
			# The parameters provided by the user are stored in a Tulip DataSet 
			# and can be accessed through the "dataSet" class attribute
			# (see documentation of class tlp.DataSet).
	
			# The method must return a boolean indicating if the algorithm
			# has been successfully applied on the input graph.
			return True
	
	# The line below does the magic to register the plugin to the plugin database
	# and updates the GUI to make it accessible through the menus.
	tulipplugins.registerAlgorithmPluginOfGroup("GeneralAlgorithmExample", "General Algorithm Demo", "author", "26/07/2011", "infos", "1.0", "Python")

Writing a selection algorithm in Python
----------------------------------------

A selection algorithm must implement the :class:`tlp.BooleanAlgorithm` interface as illustrated below::

	from tulip import *
	import tulipplugins
	
	class SelectionAlgorithmExample(tlp.BooleanAlgorithm):
		def __init__(self, context):
			tlp.BooleanAlgorithm.__init__(self, context)
			# you can add parameters to the plugin here through the following syntax
			# self.add<Type>Parameter("<paramName>", "<paramDoc>", "<paramDefaultValue>")
			# (see documentation of class tlp.WithParameter to see what types of parameters are supported)
	
		def check(self):
			# This method is called before applying the algorithm on the input graph.
			# You can perform some precondition checks here.
			# See comments in the run method to know how to access to the input graph.
	
			# Must return a tuple (boolean, string). First member indicates if the algorithm can be applied
			# and the second one can be used to provide an error message
			return (True, "Ok")
	
		def run(self):
			# This method is the entry point of the algorithm when it is called
			# and must contain its implementation.
	
			# The graph on which the algorithm is applied can be accessed through
			# the "graph" class attribute (see documentation of class tlp.Graph).

			# The parameters provided by the user are stored in a Tulip DataSet 
			# and can be accessed through the "dataSet" class attribute
			# (see documentation of class tlp.DataSet).
	
			# The result of this selection algorithm must be stored in the
			# boolean property accessible through the "booleanResult" class attribute
			# (see documentation to know how to work with graph properties).

			# The method must return a boolean indicating if the algorithm
			# has been successfully applied on the input graph.
			return True
	
	# The line below does the magic to register the plugin to the plugin database
	# and updates the GUI to make it accessible through the menus.
	tulipplugins.registerBooleanPluginOfGroup("SelectionAlgorithmExample", "Selection Algorithm Demo", "author", "27/07/2011", "infos", "1.0", "Python")

Writing a color algorithm in Python
----------------------------------------		

A color algorithm must implement the :class:`tlp.ColorAlgorithm` interface as illustrated below::

	from tulip import *
	import tulipplugins
	
	class ColorAlgorithmExample(tlp.ColorAlgorithm):
		def __init__(self, context):
			tlp.ColorAlgorithm.__init__(self, context)
			# you can add parameters to the plugin here through the following syntax
			# self.add<Type>Parameter("<paramName>", "<paramDoc>", "<paramDefaultValue>")
			# (see documentation of class tlp.WithParameter to see what types of parameters are supported)
	
		def check(self):
			# This method is called before applying the algorithm on the input graph.
			# You can perform some precondition checks here.
			# See comments in the run method to know how to access to the input graph.
	
			# Must return a tuple (boolean, string). First member indicates if the algorithm can be applied
			# and the second one can be used to provide an error message
			return (True, "Ok")
	
		def run(self):
			# This method is the entry point of the algorithm when it is called
			# and must contain its implementation.	
	
			# The graph on which the algorithm is applied can be accessed through
			# the "graph" class attribute (see documentation of class tlp.Graph).
	
			# The parameters provided by the user are stored in a Tulip DataSet 
			# and can be accessed through the "dataSet" class attribute
			# (see documentation of class tlp.DataSet).
	
			# The result of this color algorithm must be stored in the
			# color property accessible through the "colorResult" class attribute
			# (see documentation to know how to work with graph properties).
	
			# The method must return a boolean indicating if the algorithm
			# has been successfully applied on the input graph.
			return True
	
	# The line below does the magic to register the plugin to the plugin database
	# and updates the GUI to make it accessible through the menus.
	tulipplugins.registerColorPluginOfGroup("ColorAlgorithmExample", "Color Algorithm Demo", "author", "27/07/2011", "infos", "1.0", "Python")
	
Writing a metric algorithm in Python
----------------------------------------	
		
A metric algorithm must implement the :class:`tlp.DoubleAlgorithm` interface as illustrated below::

	from tulip import *
	import tulipplugins
	
	class MetricAlgorithmExample(tlp.DoubleAlgorithm):
		def __init__(self, context):
			tlp.DoubleAlgorithm.__init__(self, context)
			# you can add parameters to the plugin here through the following syntax
			# self.add<Type>Parameter("<paramName>", "<paramDoc>", "<paramDefaultValue>")
			# (see documentation of class tlp.WithParameter to see what types of parameters are supported)
	
		def check(self):
			# This method is called before applying the algorithm on the input graph.
			# You can perform some precondition checks here.
			# See comments in the run method to know how to access to the input graph.
	
			# Must return a tuple (boolean, string). First member indicates if the algorithm can be applied
			# and the second one can be used to provide an error message
			return (True, "Ok")
	
		def run(self):
			# This method is the entry point of the algorithm when it is called
			# and must contain its implementation.
	
			# The graph on which the algorithm is applied can be accessed through
			# the "graph" class attribute (see documentation of class tlp.Graph).
	
			# The parameters provided by the user are stored in a Tulip DataSet 
			# and can be accessed through the "dataSet" class attribute
			# (see documentation of class tlp.DataSet).
	
			# The result of this measure algorithm must be stored in the
			# double property accessible through the "doubleResult" class attribute
			# (see documentation to know how to work with graph properties).
	
			# The method must return a boolean indicating if the algorithm
			# has been successfully applied on the input graph.
			return True
	
	# The line below does the magic to register the plugin to the plugin database
	# and updates the GUI to make it accessible through the menus.
	tulipplugins.registerDoublePluginOfGroup("MetricAlgorithmExample", "Metric Algorithm Demo", "author", "27/07/2011", "infos", "1.0", "Python")

Writing an integer algorithm in Python
----------------------------------------	

An integer algorithm must implement the :class:`tlp.IntegerAlgorithm` interface as illustrated below::

	from tulip import *
	import tulipplugins
	
	class IntegerAlgorithmExample(tlp.IntegerAlgorithm):
		def __init__(self, context):
			tlp.IntegerAlgorithm.__init__(self, context)
			# you can add parameters to the plugin here through the following syntax
			# self.add<Type>Parameter("<paramName>", "<paramDoc>", "<paramDefaultValue>")
			# (see documentation of class tlp.WithParameter to see what types of parameters are supported)
	
		def check(self):
			# This method is called before applying the algorithm on the input graph.
			# You can perform some precondition checks here.
			# See comments in the run method to know how to access to the input graph.
	
			# Must return a tuple (boolean, string). First member indicates if the algorithm can be applied
			# and the second one can be used to provide an error message
			return (True, "Ok")
	
		def run(self):
			# This method is the entry point of the algorithm when it is called
			# and must contain its implementation.
	
			# The graph on which the algorithm is applied can be accessed through
			# the "graph" class attribute (see documentation of class tlp.Graph).
	
			# The parameters provided by the user are stored in a Tulip DataSet 
			# and can be accessed through the "dataSet" class attribute
			# (see documentation of class tlp.DataSet).
	
			# The result of this integer algorithm must be stored in the
			# integer property accessible through the "integerResult" class attribute
			# (see documentation to know how to work with graph properties).
	
			# The method must return a boolean indicating if the algorithm
			# has been successfully applied on the input graph.
			return True
	
	# The line below does the magic to register the plugin to the plugin database
	# and updates the GUI to make it accessible through the menus.
	tulipplugins.registerIntegerPluginOfGroup("IntegerAlgorithmExample", "Integer Algorithm Demo", "author", "27/07/2011", "infos", "1.0", "Python")
	
Writing a layout algorithm in Python
----------------------------------------

A layout algorithm must implement the :class:`tlp.LayoutAlgorithm` interface as illustrated below::

	from tulip import *
	import tulipplugins
	
	class LayoutAlgorithmExample(tlp.LayoutAlgorithm):
		def __init__(self, context):
			tlp.LayoutAlgorithm.__init__(self, context)
			# you can add parameters to the plugin here through the following syntax
			# self.add<Type>Parameter("<paramName>", "<paramDoc>", "<paramDefaultValue>")
			# (see documentation of class tlp.WithParameter to see what types of parameters are supported)
	
		def check(self):
			# This method is called before applying the algorithm on the input graph.
			# You can perform some precondition checks here.
			# See comments in the run method to know how to access to the input graph.
	
			# Must return a tuple (boolean, string). First member indicates if the algorithm can be applied
			# and the second one can be used to provide an error message
			return (True, "Ok")
	
		def run(self):
			# This method is the entry point of the algorithm when it is called
			# and must contain its implementation.
	
			# The graph on which the algorithm is applied can be accessed through
			# the "graph" class attribute (see documentation of class tlp.Graph).
	
			# The parameters provided by the user are stored in a Tulip DataSet 
			# and can be accessed through the "dataSet" class attribute
			# (see documentation of class tlp.DataSet).
	
			# The result of this layout algorithm must be stored in the
			# layout property accessible through the "layoutResult" class attribute
			# (see documentation to know how to work with graph properties).
	
			# The method must return a boolean indicating if the algorithm
			# has been successfully applied on the input graph.
			return True
	
	# The line below does the magic to register the plugin to the plugin database
	# and updates the GUI to make it accessible through the menus.
	tulipplugins.registerLayoutPluginOfGroup("LayoutAlgorithmExample", "Layout Algorithm Demo", "author", "27/07/2011", "infos", "1.0", "Python")
	
Writing a size algorithm in Python
----------------------------------------

A size algorithm must implement the :class:`tlp.SizeAlgorithm` interface as illustrated below::

	from tulip import *
	import tulipplugins
	
	class SizeAlgorithmExample(tlp.SizeAlgorithm):
		def __init__(self, context):
			tlp.SizeAlgorithm.__init__(self, context)
			# you can add parameters to the plugin here through the following syntax
			# self.add<Type>Parameter("<paramName>", "<paramDoc>", "<paramDefaultValue>")
			# (see documentation of class tlp.WithParameter to see what types of parameters are supported)
	
		def check(self):
			# This method is called before applying the algorithm on the input graph.
			# You can perform some precondition checks here.
			# See comments in the run method to know how to access to the input graph.
	
			# Must return a tuple (boolean, string). First member indicates if the algorithm can be applied
			# and the second one can be used to provide an error message
			return (True, "Ok")
	
		def run(self):
			# This method is the entry point of the algorithm when it is called
			# and must contain its implementation.
	
			# The graph on which the algorithm is applied can be accessed through
			# the "graph" class attribute (see documentation of class tlp.Graph).
	
			# The parameters provided by the user are stored in a Tulip DataSet 
			# and can be accessed through the "dataSet" class attribute
			# (see documentation of class tlp.DataSet).
	
			# The result of this size algorithm must be stored in the
			# size property accessible through the "sizeResult" class attribute
			# (see documentation to know how to work with graph properties).
	
			# The method must return a boolean indicating if the algorithm
			# has been successfully applied on the input graph.
			return True
	
	# The line below does the magic to register the plugin to the plugin database
	# and updates the GUI to make it accessible through the menus.
	tulipplugins.registerSizePluginOfGroup("SizeAlgorithmExample", "Size Algorithm Demo", "author", "27/07/2011", "infos", "1.0", "Python")	

Writing an export module in Python
-----------------------------------

An export module must implement the :class:`tlp.ExportModule` interface as illustrated below::

	from tulip import *
	import tulipplugins
	
	class ExportModuleExample(tlp.ExportModule):
		def __init__(self, context):
			tlp.ExportModule.__init__(self, context)
			# you can add parameters to the plugin here through the following syntax
			# self.add<Type>Parameter("<paramName>", "<paramDoc>", "<paramDefaultValue>")
			# (see documentation of class tlp.WithParameter to see what types of parameters are supported)
	
		def exportGraph(self, os):
			# This method is called to export a graph.
			# The graph to export is accessible through the "graph" class attribute
			# (see documentation of class tlp.Graph).
			
			# The parameters provided by the user are stored in a Tulip DataSet 
			# and can be accessed through the "dataSet" class attribute
			# (see documentation of class tlp.DataSet).
	
			# The os parameter is an output file stream (initialized by the Tulip GUI
			# or by the tlp.exportGraph function.). 
			# To write data to the file, you have to use the following syntax :

			# write the number of nodes and edges to the file
			os << self.graph.numberOfNodes() << "\n"
			os << self.graph.numberOfEdges() << "\n"
	
			# The method must return a boolean indicating if the
			# graph has been successfully exported.
			return True
	
	# The line below does the magic to register the plugin to the plugin database
	# and updates the GUI to make it accessible through the menus.
	tulipplugins.registerExportPluginOfGroup("ExportModuleExample", "Export Module Demo", "author", "27/07/2011", "infos", "1.0", "Python")

Writing an import module in Python
-----------------------------------		

An import module must implement the :class:`tlp.ImportModule` interface as illustrated below::

	from tulip import *
	import tulipplugins
	
	class ImportModuleExample(tlp.ImportModule):
		def __init__(self, context):
			tlp.ImportModule.__init__(self, context)
			# you can add parameters to the plugin here through the following syntax
			# self.add<Type>Parameter("<paramName>", "<paramDoc>", "<paramDefaultValue>")
			# (see documentation of class tlp.WithParameter to see what types of parameters are supported)
	
		def importGraph(self):
			# This method is called to import a new graph.
			# An empty graph to populate is accessible through the "graph" class attribute
			# (see documentation of class tlp.Graph).
	
			# The parameters provided by the user are stored in a Tulip DataSet 
			# and can be accessed through the "dataSet" class attribute
			# (see documentation of class tlp.DataSet).
	
			# The method must return a boolean indicating if the
			# graph has been successfully imported.
			return True
	
	# The line below does the magic to register the plugin to the plugin database
	# and updates the GUI to make it accessible through the menus.
	tulipplugins.registerImportPluginOfGroup("ImportModuleExample", "Import Module Demo", "author", "27/07/2011", "infos", "1.0", "Python")