File: meshutils.py

package info (click to toggle)
vistrails 2.1.1-1
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 74,208 kB
  • ctags: 46,250
  • sloc: python: 316,267; xml: 52,512; sql: 3,627; php: 731; sh: 260; makefile: 108
file content (104 lines) | stat: -rw-r--r-- 3,312 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
import core.modules
import core.modules.module_registry
from core.modules.vistrails_module import Module, ModuleError
import core.bundles
import core.requirements
import os
import re

identifier = 'edu.utah.sci.cscheid.meshutils'
version = '0.1'
name = 'Mesh utility'

class MeshArea(Module):

    def compute(self):
        self.checkInputPort('input_file')
        f1 = self.getInputFromPort('input_file')
        text_output = self.interpreter.filePool.create_file()

        cmdline = []
        cmdline.append(meshareapath)
        cmdline.append(f1.name)
        cmdline.append('>' + text_output.name)
        cmdline = ('%s ' * len(cmdline)) % tuple(cmdline)
        print cmdline
        result = os.system(cmdline)
        if result != 0:
            raise ModuleError(self, "execution failed")
        try:
            l = file(text_output.name).readlines()[-1]
            v = float(l)
        except:
            raise ModuleError(self, "Expected a float, got '%s'" % l)
        self.setResult('area', v)

class MeshChoose(Module):

    def guess_input_format(self, input_file_name):
        i = input_file_name.rfind('.')
        if i == -1:
            return None
        else:
            return input_file_name[i:]

    def compute(self):
        self.checkInputPort('input_file_1')
        self.checkInputPort('input_file_2')

        input_file_1 = self.getInputFromPort('input_file_1')
        input_file_2 = self.getInputFromPort('input_file_2')

        if self.hasInputFromPort('output_format'):
            output_suffix = self.getInputFromPort('output_format')
        else:
            output_suffix = self.guess_input_format(input_file_2.name)

        output_file = self.interpreter.filePool.create_file(output_suffix)

        cmdline = [meshchoosepath,
                   input_file_1.name,
                   input_file_2.name,
                   output_file.name]
        cmdline = ('%s ' * len(cmdline)) % tuple(cmdline)
        print cmdline
        result = os.system(cmdline)
        if result != 0:
            raise ModuleError(self, "execution failed")
        self.setResult('output_file', output_file)

def setpath(prefix):
    global meshareapath
    meshareapath = prefix + 'mesh_area'
    global meshchoosepath
    meshchoosepath = prefix + 'mesh_choose'

def initialize(meshutilspath=None):
    global _mesh_utils_path
    if not meshutilspath:
        print "Assuming mesh_utils are on path"
        setpath('')
    else:
        print "Assuming mesh_utils are in '%s/'" % meshutilspath
        setpath(meshutilspath+'/')
    reg = core.modules.module_registry
    reg.add_module(MeshArea)
    reg.add_input_port(MeshArea, 'input_file',
                     core.modules.basic_modules.File)
    reg.add_output_port(MeshArea, 'area',
                      core.modules.basic_modules.Float)

    reg.add_module(MeshChoose)
    reg.add_input_port(MeshChoose, 'input_file_1',
                     core.modules.basic_modules.File)
    reg.add_input_port(MeshChoose, 'input_file_2',
                     core.modules.basic_modules.File)
    reg.add_input_port(MeshChoose, 'output_format',
                     core.modules.basic_modules.String)

    reg.add_output_port(MeshChoose, 'output_file',
                      core.modules.basic_modules.File)