ClangFormat: apply to source, most of intern
[blender.git] / intern / openvdb / intern / openvdb_reader.cc
1 /*
2  * This program is free software; you can redistribute it and/or
3  * modify it under the terms of the GNU General Public License
4  * as published by the Free Software Foundation; either version 2
5  * of the License, or (at your option) any later version.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program; if not, write to the Free Software Foundation,
14  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
15  *
16  * The Original Code is Copyright (C) 2015 Blender Foundation.
17  * All rights reserved.
18  */
19
20 #include "openvdb_reader.h"
21 #include "openvdb_util.h"
22
23 OpenVDBReader::OpenVDBReader() : m_meta_map(new openvdb::MetaMap), m_file(NULL)
24 {
25   /* Although it is safe, it may not be good to have this here, could be done
26    * once instead of everytime we read a file. */
27   openvdb::initialize();
28 }
29
30 OpenVDBReader::~OpenVDBReader()
31 {
32   cleanupFile();
33 }
34
35 void OpenVDBReader::open(const openvdb::Name &filename)
36 {
37   cleanupFile();
38
39   try {
40     m_file = new openvdb::io::File(filename);
41     m_file->setCopyMaxBytes(0);
42     m_file->open();
43
44     m_meta_map = m_file->getMetadata();
45   }
46   /* Mostly to catch exceptions related to Blosc not being supported. */
47   catch (const openvdb::IoError &e) {
48     std::cerr << e.what() << '\n';
49     cleanupFile();
50   }
51 }
52
53 void OpenVDBReader::floatMeta(const openvdb::Name &name, float &value) const
54 {
55   try {
56     value = m_meta_map->metaValue<float>(name);
57   }
58   CATCH_KEYERROR;
59 }
60
61 void OpenVDBReader::intMeta(const openvdb::Name &name, int &value) const
62 {
63   try {
64     value = m_meta_map->metaValue<int>(name);
65   }
66   CATCH_KEYERROR;
67 }
68
69 void OpenVDBReader::vec3sMeta(const openvdb::Name &name, float value[3]) const
70 {
71   try {
72     openvdb::Vec3s meta_val = m_meta_map->metaValue<openvdb::Vec3s>(name);
73
74     value[0] = meta_val.x();
75     value[1] = meta_val.y();
76     value[2] = meta_val.z();
77   }
78   CATCH_KEYERROR;
79 }
80
81 void OpenVDBReader::vec3IMeta(const openvdb::Name &name, int value[3]) const
82 {
83   try {
84     openvdb::Vec3i meta_val = m_meta_map->metaValue<openvdb::Vec3i>(name);
85
86     value[0] = meta_val.x();
87     value[1] = meta_val.y();
88     value[2] = meta_val.z();
89   }
90   CATCH_KEYERROR;
91 }
92
93 void OpenVDBReader::mat4sMeta(const openvdb::Name &name, float value[4][4]) const
94 {
95   try {
96     openvdb::Mat4s meta_val = m_meta_map->metaValue<openvdb::Mat4s>(name);
97
98     for (int i = 0; i < 4; ++i) {
99       for (int j = 0; j < 4; ++j) {
100         value[i][j] = meta_val[i][j];
101       }
102     }
103   }
104   CATCH_KEYERROR;
105 }
106
107 bool OpenVDBReader::hasGrid(const openvdb::Name &name) const
108 {
109   return m_file->hasGrid(name);
110 }
111
112 openvdb::GridBase::Ptr OpenVDBReader::getGrid(const openvdb::Name &name) const
113 {
114   return m_file->readGrid(name);
115 }
116
117 size_t OpenVDBReader::numGrids() const
118 {
119   return m_file->getGrids()->size();
120 }
121
122 void OpenVDBReader::cleanupFile()
123 {
124   if (m_file) {
125     m_file->close();
126     delete m_file;
127   }
128 }