File: interface.cpp

package info (click to toggle)
ffc 2019.2.0~git20210714.a20cbe7-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 8,228 kB
  • sloc: cpp: 45,285; python: 27,903; sh: 11,386; ansic: 1,069; makefile: 499
file content (56 lines) | stat: -rw-r--r-- 1,793 bytes parent folder | download | duplicates (2)
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
// Copyright (C) 2017 Garth N. Wells
//
// This file is part of FFC.
//
// FFC is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// FFC is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with FFC. If not, see <http://www.gnu.org/licenses/>.

#include <memory>
#include <pybind11/pybind11.h>
#include <ufc.h>

namespace py = pybind11;

namespace ufc_wrappers
{
  void finite_element(py::module& m);
  void dofmap(py::module& m);
}

PYBIND11_MODULE(ffc_factory, m)
{
  m.doc() = "Factory for wrapping FFC JIT-compiled objects";

  // Create finite_element submodule
  py::module finite_element = m.def_submodule("finite_element",
                                              "UFC finite_element");
  ufc_wrappers::finite_element(finite_element);

  // Create dofmap submodule
  py::module dofmap = m.def_submodule("dofmap", "UFC dofmap");
  ufc_wrappers::dofmap(dofmap);

  // Factory functions
  m.def("make_ufc_finite_element",
        [](std::uintptr_t e)
        {
          ufc::finite_element * p = reinterpret_cast<ufc::finite_element *>(e);
          return std::shared_ptr<const ufc::finite_element>(p);
        });
  m.def("make_ufc_dofmap",
        [](std::uintptr_t e)
        {
          ufc::dofmap * p = reinterpret_cast<ufc::dofmap *>(e);
          return std::shared_ptr<const ufc::dofmap>(p);
        });
}