This file is indexed.

/usr/bin/form2ufl is in python-ufl 1.6.0-1.

This file is owned by root:root, with mode 0o755.

The actual contents of the file can be viewed below.

  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
#! /usr/bin/python
#
# Simple conversion script from old FFC .form format to UFL format

__authors__ = "Anders Logg"
__date__ = "2008-08-01 -- 2009-03-15"

import sys
import re
from os.path import exists

def help():
    print("Simple conversion script from old FFC .form format to UFL format.")
    print("")
    print("Usage: form2ufl <filename>.form")

def error(message=None):
    if not message is None:
        print(message)
    else:
        help()
    sys.exit(1)

def split_at_closing_brace(s):
    num_left = num_right = 0
    for (i, c) in enumerate(s):
        if c == "(":
            num_left += 1
        elif c == ")":
            num_right += 1
        if num_left == num_right:
            return s[:i + 1], s[i + 1:]
    return s, ""

def replace_transp(match):
    expr1, expr2 = split_at_closing_brace(match.groups()[0])
    return expr1 + ".T" + expr2

def replace_mult(match):
    start, end = split_at_closing_brace(match.groups()[0])
    expr1 = start.split(",")[0][1:].strip()
    expr2 = start.split(",")[1][:-1].strip()
    if "+" in expr1:
        expr1 = "(%s)" % expr1
    if "+" in expr2:
        expr2 = "(%s)" % expr2
    return expr1 + "*" + expr2 + end

def form2ufl(code):

    # List of simple replacements
    simple_replacements = ((r"\.form",                    ".ufl"),
                           (r"\bdot\b",                   "inner"),
                           (r"\bD\b",                     "Dx"),
                           (r"\bmodulus\b",               "abs"),
                           (r'"interval"',                "interval"),
                           (r'"triangle"',                "triangle"),
                           (r'"tetrahedron"',             "tetrahedron"),
                           (r'MeshSize',                  "Constant"),
                           (r'FacetNormal',               "VectorConstant"),
                           (r"Nedelec",                   "N1curl"),
                           (r"VectorQuadratureElement\(", 'VectorElement("Quadrature", '),
                           (r"QuadratureElement\(",       'FiniteElement("Quadrature", '))

    # List of complex replacements
    complex_replacements = ((r"\btransp(.*)", replace_transp),
                            (r"\bmult(.*)",   replace_mult))

    # Iterate over replacemens
    for (a, b) in simple_replacements + complex_replacements:
        code = re.sub(a, b, code)

    return code

def main(args):

    # Check command-line arguments
    if not len(args) == 1:
        error()

    # Get prefix and filenames
    words = args[0].split(".form")
    if not (len(words) == 2 and words[1] == ""):
        error()
    prefix = words[0]
    form_filename = prefix + ".form"
    ufl_filename = prefix + ".ufl"

    # Check if outfile exists
    if exists(ufl_filename):
        error("File already exists: " + ufl_filename)

    print("Converting %s --> %s" % (form_filename, ufl_filename))

    # Read file
    try:
        file = open(form_filename, "r")
        code = file.read()
        file.close()
    except:
        error("Unable to read file: " + form_filename)

    # Convert to UFL
    code = form2ufl(code)

    # Write file
    try:
        file = open(ufl_filename, "w")
        file.write(code)
        file.close()
    except:
        error("Unable to write to file: " + ufl_filename)

if __name__ == "__main__":
    main(sys.argv[1:])
    sys.exit(0)