Source code for ufl.algorithms.check_restrictions
# -*- coding: utf-8 -*-
"Algorithms related to restrictions."
# Copyright (C) 2008-2016 Martin Sandve Alnæs
#
# This file is part of UFL (https://www.fenicsproject.org)
#
# SPDX-License-Identifier: LGPL-3.0-or-later
from ufl.log import error
from ufl.corealg.multifunction import MultiFunction
from ufl.corealg.map_dag import map_expr_dag
[docs]class RestrictionChecker(MultiFunction):
def __init__(self, require_restriction):
MultiFunction.__init__(self)
self.current_restriction = None
self.require_restriction = require_restriction
[docs] def expr(self, o):
pass
[docs] def restricted(self, o):
if self.current_restriction is not None:
error("Not expecting twice restricted expression.")
self.current_restriction = o._side
e, = o.ufl_operands
self.visit(e)
self.current_restriction = None
[docs] def facet_normal(self, o):
if self.require_restriction:
if self.current_restriction is None:
error("Facet normal must be restricted in interior facet integrals.")
else:
if self.current_restriction is not None:
error("Restrictions are only allowed for interior facet integrals.")
[docs]def check_restrictions(expression, require_restriction):
"Check that types that must be restricted are restricted in expression."
rules = RestrictionChecker(require_restriction)
return map_expr_dag(rules, expression)