Loading [MathJax]/extensions/tex2jax.js
LSST Applications 28.0.0,g1653933729+a8ce1bb630,g1a997c3884+a8ce1bb630,g28da252d5a+5bd70b7e6d,g2bbee38e9b+638fca75ac,g2bc492864f+638fca75ac,g3156d2b45e+07302053f8,g347aa1857d+638fca75ac,g35bb328faa+a8ce1bb630,g3a166c0a6a+638fca75ac,g3e281a1b8c+7bbb0b2507,g4005a62e65+17cd334064,g414038480c+5b5cd4fff3,g41af890bb2+4ffae9de63,g4e1a3235cc+0f1912dca3,g6249c6f860+3c3976f90c,g80478fca09+46aba80bd6,g82479be7b0+77990446f6,g858d7b2824+78ba4d1ce1,g89c8672015+f667a5183b,g9125e01d80+a8ce1bb630,ga5288a1d22+2a6264e9ca,gae0086650b+a8ce1bb630,gb58c049af0+d64f4d3760,gc22bb204ba+78ba4d1ce1,gc28159a63d+638fca75ac,gcf0d15dbbd+32ddb6096f,gd6b7c0dfd1+3e339405e9,gda3e153d99+78ba4d1ce1,gda6a2b7d83+32ddb6096f,gdaeeff99f8+1711a396fd,gdd5a9049c5+b18c39e5e3,ge2409df99d+a5e4577cdc,ge33fd446bb+78ba4d1ce1,ge79ae78c31+638fca75ac,gf0baf85859+64e8883e75,gf5289d68f6+e1b046a8d7,gfa443fc69c+91d9ed1ecf,gfda6b12a05+8419469a56
LSST Data Management Base Package
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
base.cc
Go to the documentation of this file.
1#include "astshim/base.h"
2
3#include <sstream>
4#include <stdexcept>
5#include <string>
6#include <vector>
7
8namespace ast {
9namespace {
10
11static std::ostringstream errorMsgStream;
12
13/*
14Write an error message to `errorMsgStream`
15
16Intended to be registered as an error handler to AST by calling `astSetPutErr(reportError)`.
17*/
18void reportError(int errNum, const char *errMsg) { errorMsgStream << errMsg; }
19
20/*
21Instantiate this class to register `reportError` as an AST error handler.
22*/
23class ErrorHandler {
24public:
25 ErrorHandler() { astSetPutErr(reportError); }
26
27 ErrorHandler(ErrorHandler const &) = delete;
28 ErrorHandler(ErrorHandler &&) = delete;
29 ErrorHandler &operator=(ErrorHandler const &) = delete;
30 ErrorHandler &operator=(ErrorHandler &&) = delete;
31
32 static std::string getErrMsg() {
33 auto errMsg = errorMsgStream.str();
34 // clear status bits
35 errorMsgStream.clear();
36 if (errMsg.empty()) {
37 errMsg = "Failed with AST status = " + std::to_string(astStatus);
38 } else {
39 // empty the stream
40 errorMsgStream.str("");
41 }
42 astClearStatus;
43 return errMsg;
44 }
45};
46
47} // namespace
48
49void assertOK(AstObject *rawPtr1, AstObject *rawPtr2) {
50 // Construct ErrorHandler once, the first time this function is called.
51 // This is done to initialize `errorMsgStream` and register `reportError` as the AST error handler.
52 // See https://isocpp.org/wiki/faq/ctors#static-init-order-on-first-use
53 static ErrorHandler *errHandler = new ErrorHandler();
54 if (!astOK) {
55 if (rawPtr1) {
56 astAnnul(rawPtr1);
57 }
58 if (rawPtr2) {
59 astAnnul(rawPtr2);
60 }
61 throw std::runtime_error(errHandler->getErrMsg());
62 }
63}
64
66 return static_cast<ConstArray2D>(arrayFromVector(const_cast<std::vector<double> &>(vec), nAxes));
67}
68
70 int nPoints = vec.size() / nAxes;
71 if (nPoints * nAxes != vec.size()) {
73 os << "vec length = " << vec.size() << " not a multiple of nAxes = " << nAxes;
74 throw std::runtime_error(os.str());
75 }
76 Array2D::Index shape = ndarray::makeVector(nAxes, nPoints);
77 Array2D::Index strides = ndarray::makeVector(nPoints, 1);
78 return external(vec.data(), shape, strides);
79}
80
81} // namespace ast
std::ostream * os
Definition Schema.cc:557
T clear(T... args)
T data(T... args)
AST wrapper classes and functions.
ndarray::Array< const double, 2, 2 > ConstArray2D
2D array of const double; typically used for lists of const points
Definition base.h:46
ndarray::Array< double, 2, 2 > Array2D
2D array of const double; typically used for lists of const points
Definition base.h:42
void assertOK(AstObject *rawPtr1=nullptr, AstObject *rawPtr2=nullptr)
Throw std::runtime_error if AST's state is bad.
Definition base.cc:49
ConstArray2D arrayFromVector(std::vector< double > const &vec, int nAxes)
Reshape a vector as a 2-dimensional array that shares the same memory.
Definition base.cc:65
T size(T... args)
T str(T... args)
T to_string(T... args)