diff options
author | Hans Goudey <h.goudey@me.com> | 2022-06-01 12:57:38 +0300 |
---|---|---|
committer | Hans Goudey <h.goudey@me.com> | 2022-06-01 12:57:38 +0300 |
commit | e9eae1b8577b38f2d17763e230a8313a3881d7c5 (patch) | |
tree | 976bc3e00d565dd68c7b841e1906749a6b601d2c /source/blender/editors/curves/intern | |
parent | 110c90b3cfc94daead190dfb9adbc4761e6960b8 (diff) |
Curves: Avoid optimization to avoid storing selection for now
This optimization should be restored when there is proper vizualization
for the selection attributes.
Diffstat (limited to 'source/blender/editors/curves/intern')
-rw-r--r-- | source/blender/editors/curves/intern/curves_ops.cc | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/source/blender/editors/curves/intern/curves_ops.cc b/source/blender/editors/curves/intern/curves_ops.cc index 0e12257be58..85214e1608d 100644 --- a/source/blender/editors/curves/intern/curves_ops.cc +++ b/source/blender/editors/curves/intern/curves_ops.cc @@ -848,10 +848,21 @@ static int select_all_exec(bContext *C, wmOperator *op) for (Curves *curves_id : unique_curves) { if (action == SEL_SELECT) { + /* The optimization to avoid storing the selection when everything is selected causes too + * many problems at the moment, since there is no proper visualization yet. Keep the code but + * disable it for now. */ +#if 0 CurveComponent component; component.replace(curves_id, GeometryOwnershipType::Editable); component.attribute_try_delete(".selection_point_float"); component.attribute_try_delete(".selection_curve_float"); +#else + CurvesGeometry &curves = CurvesGeometry::wrap(curves_id->geometry); + MutableSpan<float> selection = curves_id->selection_domain == ATTR_DOMAIN_POINT ? + curves.selection_point_float_for_write() : + curves.selection_curve_float_for_write(); + selection.fill(1.0f); +#endif } else { CurvesGeometry &curves = CurvesGeometry::wrap(curves_id->geometry); |