OmniSciDB  06b3bd477c
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
ArrowUtil.h
Go to the documentation of this file.
1 /*
2  * Copyright 2017 MapD Technologies, Inc.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef QUERYENGINE_ARROW_UTIL_H
18 #define QUERYENGINE_ARROW_UTIL_H
19 
20 #include "arrow/status.h"
21 #include "arrow/util/macros.h"
22 
23 #include "Shared/likely.h"
24 
26 
27 inline void arrow_status_throw(const ::arrow::Status& s) {
28  std::string message = s.ToString();
29  switch (s.code()) {
30  case ::arrow::StatusCode::OutOfMemory:
31  throw OutOfMemory(message);
32  default:
33  throw std::runtime_error(message);
34  }
35 }
36 
37 #define ARROW_THROW_NOT_OK(s) \
38  do { \
39  ::arrow::Status _s = (s); \
40  if (UNLIKELY(!_s.ok())) { \
41  arrow_status_throw(_s); \
42  } \
43  } while (0)
44 
45 #endif // QUERYENGINE_ARROW_UTIL_H
void arrow_status_throw(const ::arrow::Status &s)
Definition: ArrowUtil.h:27