Message ID | 20241118221618.13953-4-laurent.pinchart@ideasonboard.com |
---|---|
State | Superseded |
Headers | show |
Series |
|
Related | show |
Hi 2024. november 18., hétfő 23:16 keltezéssel, Laurent Pinchart <laurent.pinchart@ideasonboard.com> írta: > The default constructor leaves the vector data uninitialized. Add a > constructor to fill the vector with copies of a scalar value, and fix > the documentation of the default constructor. > > Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> > --- > src/ipa/libipa/vector.cpp | 8 +++++++- > src/ipa/libipa/vector.h | 5 +++++ > 2 files changed, 12 insertions(+), 1 deletion(-) > > diff --git a/src/ipa/libipa/vector.cpp b/src/ipa/libipa/vector.cpp > index f14f155216f3..d414ba97e41e 100644 > --- a/src/ipa/libipa/vector.cpp > +++ b/src/ipa/libipa/vector.cpp > @@ -29,7 +29,13 @@ namespace ipa { > > /** > * \fn Vector::Vector() > - * \brief Construct a zero vector > + * \brief Construct an uninitialized vector > + */ > + > +/** > + * \fn Vector::Vector(T scalar) > + * \brief Construct a vector filled with a \a scalar value > + * \param[in] scalar The scalar value > */ > > /** > diff --git a/src/ipa/libipa/vector.h b/src/ipa/libipa/vector.h > index b72ab9851aa3..be568eadfeac 100644 > --- a/src/ipa/libipa/vector.h > +++ b/src/ipa/libipa/vector.h > @@ -35,6 +35,11 @@ class Vector > public: > constexpr Vector() = default; > > + constexpr Vector(T scalar) > + { > + data_.fill(scalar); > + } > + Is there an expectation that e.g. `Vector<int, 3> x = 1` works? If not, then I think adding `explicit` would be something to consider to avoid erroneous construction from a scalar, especially in function calls. Regards, Barnabás Pőcze > constexpr Vector(const std::array<T, Rows> &data) > { > for (unsigned int i = 0; i < Rows; i++) > -- > Regards, > > Laurent Pinchart
On Mon, Nov 18, 2024 at 11:49:16PM +0000, Barnabás Pőcze wrote: > Hi > > > 2024. november 18., hétfő 23:16 keltezéssel, Laurent Pinchart <laurent.pinchart@ideasonboard.com> írta: > > > The default constructor leaves the vector data uninitialized. Add a > > constructor to fill the vector with copies of a scalar value, and fix > > the documentation of the default constructor. > > > > Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> > > --- > > src/ipa/libipa/vector.cpp | 8 +++++++- > > src/ipa/libipa/vector.h | 5 +++++ > > 2 files changed, 12 insertions(+), 1 deletion(-) > > > > diff --git a/src/ipa/libipa/vector.cpp b/src/ipa/libipa/vector.cpp > > index f14f155216f3..d414ba97e41e 100644 > > --- a/src/ipa/libipa/vector.cpp > > +++ b/src/ipa/libipa/vector.cpp > > @@ -29,7 +29,13 @@ namespace ipa { > > > > /** > > * \fn Vector::Vector() > > - * \brief Construct a zero vector > > + * \brief Construct an uninitialized vector > > + */ > > + > > +/** > > + * \fn Vector::Vector(T scalar) > > + * \brief Construct a vector filled with a \a scalar value > > + * \param[in] scalar The scalar value > > */ > > > > /** > > diff --git a/src/ipa/libipa/vector.h b/src/ipa/libipa/vector.h > > index b72ab9851aa3..be568eadfeac 100644 > > --- a/src/ipa/libipa/vector.h > > +++ b/src/ipa/libipa/vector.h > > @@ -35,6 +35,11 @@ class Vector > > public: > > constexpr Vector() = default; > > > > + constexpr Vector(T scalar) > > + { > > + data_.fill(scalar); > > + } > > + > > Is there an expectation that e.g. `Vector<int, 3> x = 1` works? If not, then > I think adding `explicit` would be something to consider to avoid erroneous > construction from a scalar, especially in function calls. Good point. Will fix in v4. > > constexpr Vector(const std::array<T, Rows> &data) > > { > > for (unsigned int i = 0; i < Rows; i++)
diff --git a/src/ipa/libipa/vector.cpp b/src/ipa/libipa/vector.cpp index f14f155216f3..d414ba97e41e 100644 --- a/src/ipa/libipa/vector.cpp +++ b/src/ipa/libipa/vector.cpp @@ -29,7 +29,13 @@ namespace ipa { /** * \fn Vector::Vector() - * \brief Construct a zero vector + * \brief Construct an uninitialized vector + */ + +/** + * \fn Vector::Vector(T scalar) + * \brief Construct a vector filled with a \a scalar value + * \param[in] scalar The scalar value */ /** diff --git a/src/ipa/libipa/vector.h b/src/ipa/libipa/vector.h index b72ab9851aa3..be568eadfeac 100644 --- a/src/ipa/libipa/vector.h +++ b/src/ipa/libipa/vector.h @@ -35,6 +35,11 @@ class Vector public: constexpr Vector() = default; + constexpr Vector(T scalar) + { + data_.fill(scalar); + } + constexpr Vector(const std::array<T, Rows> &data) { for (unsigned int i = 0; i < Rows; i++)
The default constructor leaves the vector data uninitialized. Add a constructor to fill the vector with copies of a scalar value, and fix the documentation of the default constructor. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> --- src/ipa/libipa/vector.cpp | 8 +++++++- src/ipa/libipa/vector.h | 5 +++++ 2 files changed, 12 insertions(+), 1 deletion(-)