vgl_io_infinite_line_3d.hxx
Go to the documentation of this file.
1 // This is core/vgl/io/vgl_io_infinite_line_3d.hxx
2 #ifndef vgl_io_infinite_line_3d_hxx_
3 #define vgl_io_infinite_line_3d_hxx_
4 //:
5 // \file
6 
7 #include <iostream>
9 #include "vgl_io_vector_2d.h"
10 #include "vgl_io_vector_3d.h"
11 
12 //======================================================================
13 //: Binary save vgl_infinite_line_3d to stream.
14 template<class T>
15 void vsl_b_write(vsl_b_ostream &os, const vgl_infinite_line_3d<T>& v)
16 {
17  constexpr short io_version_no = 1;
18  vsl_b_write(os, io_version_no);
19  vsl_b_write(os, v.x0());
20  vsl_b_write(os, v.direction());
21 }
22 
23 //======================================================================
24 //: Binary load vgl_infinite_line_3d from stream.
25 template<class T>
26 void vsl_b_read(vsl_b_istream &is, vgl_infinite_line_3d<T>& v)
27 {
28  if (!is) return;
29 
31  vgl_vector_3d<T> dir;
32  short w;
33  vsl_b_read(is, w);
34  switch (w)
35  {
36  case 1:
37  vsl_b_read(is, x0);
38  vsl_b_read(is, dir);
39  v.set(x0,dir);
40  break;
41 
42  default:
43  std::cerr << "I/O ERROR: vsl_b_read(vsl_b_istream&, vgl_infinite_line_3d<T>&)\n"
44  << " Unknown version number "<< v << '\n';
45  is.is().clear(std::ios::badbit); // Set an unrecoverable IO error on stream
46  return;
47  }
48 }
49 
50 
51 //======================================================================
52 //: Output a human readable summary of a vgl_infinite_line_3d object to the stream
53 template<class T>
54 void vsl_print_summary(std::ostream &os, const vgl_infinite_line_3d<T>& v)
55 {
56  os << "infinite_line: (position vector=" << v.x0()<< " direction=" << v.direction() <<")";
57 }
58 
59 #define VGL_IO_INFINITE_LINE_3D_INSTANTIATE(T) \
60 template void vsl_print_summary(std::ostream &, const vgl_infinite_line_3d<T >&); \
61 template void vsl_b_read(vsl_b_istream &, vgl_infinite_line_3d<T >&); \
62 template void vsl_b_write(vsl_b_ostream &, const vgl_infinite_line_3d<T >&)
63 
64 #endif // vgl_io_infinite_line_3d_hxx_
Direction vector in Euclidean 2D space, templated by type of element.
Definition: vgl_fwd.h:12
#define v
Definition: vgl_vector_2d.h:74
contains functions vsl_b_write, vsl_b_read and vsl_print_summary
Represents a 3-d line with position defined in the orthogonal plane passing through the origin.
Definition: vgl_fwd.h:20
Direction vector in Euclidean 3D space, templated by type of element.
Definition: vgl_fwd.h:13
void vsl_b_write(vsl_b_ostream &os, const vgl_infinite_line_3d< T > &v)
Binary save vgl_infinite_line_3d to stream.
void vsl_b_read(vsl_b_istream &is, vgl_infinite_line_3d< T > &v)
Binary load vgl_infinite_line_3d from stream.
void vsl_print_summary(std::ostream &os, const vgl_infinite_line_3d< T > &v)
Output a human readable summary of a vgl_infinite_line_3d object to the stream.