Compare commits
1 Commits
v0.22.1
...
achalmers/
Author | SHA1 | Date | |
---|---|---|---|
655705d3f3 |
@ -20,17 +20,12 @@ use crate::{
|
|||||||
/// Data to draw a line to a point.
|
/// Data to draw a line to a point.
|
||||||
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
||||||
#[ts(export)]
|
#[ts(export)]
|
||||||
#[serde(rename_all = "camelCase", untagged)]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub enum LineToData {
|
pub struct LineToData {
|
||||||
/// A point with a tag.
|
/// The to point.
|
||||||
PointWithTag {
|
to: [f64; 2],
|
||||||
/// The to point.
|
/// The tag.
|
||||||
to: [f64; 2],
|
tag: Option<String>,
|
||||||
/// The tag.
|
|
||||||
tag: String,
|
|
||||||
},
|
|
||||||
/// A point.
|
|
||||||
Point([f64; 2]),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Draw a line to a point.
|
/// Draw a line to a point.
|
||||||
@ -51,10 +46,8 @@ async fn inner_line_to(
|
|||||||
args: Args,
|
args: Args,
|
||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let from = sketch_group.get_coords_from_paths()?;
|
let from = sketch_group.get_coords_from_paths()?;
|
||||||
let to = match data {
|
let to = data.to;
|
||||||
LineToData::PointWithTag { to, .. } => to,
|
let name = data.tag.unwrap_or_default();
|
||||||
LineToData::Point(to) => to,
|
|
||||||
};
|
|
||||||
|
|
||||||
let id = uuid::Uuid::new_v4();
|
let id = uuid::Uuid::new_v4();
|
||||||
|
|
||||||
@ -63,11 +56,7 @@ async fn inner_line_to(
|
|||||||
ModelingCmd::ExtendPath {
|
ModelingCmd::ExtendPath {
|
||||||
path: sketch_group.id,
|
path: sketch_group.id,
|
||||||
segment: kittycad::types::PathSegment::Line {
|
segment: kittycad::types::PathSegment::Line {
|
||||||
end: Point3D {
|
end: point3d(to),
|
||||||
x: to[0],
|
|
||||||
y: to[1],
|
|
||||||
z: 0.0,
|
|
||||||
},
|
|
||||||
relative: false,
|
relative: false,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@ -78,11 +67,7 @@ async fn inner_line_to(
|
|||||||
base: BasePath {
|
base: BasePath {
|
||||||
from: from.into(),
|
from: from.into(),
|
||||||
to,
|
to,
|
||||||
name: if let LineToData::PointWithTag { tag, .. } = data {
|
name,
|
||||||
tag.to_string()
|
|
||||||
} else {
|
|
||||||
"".to_string()
|
|
||||||
},
|
|
||||||
geo_meta: GeoMeta {
|
geo_meta: GeoMeta {
|
||||||
id,
|
id,
|
||||||
metadata: args.source_range.into(),
|
metadata: args.source_range.into(),
|
||||||
@ -99,17 +84,12 @@ async fn inner_line_to(
|
|||||||
/// Data to draw a line to a point on an axis.
|
/// Data to draw a line to a point on an axis.
|
||||||
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
||||||
#[ts(export)]
|
#[ts(export)]
|
||||||
#[serde(rename_all = "camelCase", untagged)]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub enum AxisLineToData {
|
pub struct AxisLineToData {
|
||||||
/// A point with a tag.
|
/// The to point.
|
||||||
PointWithTag {
|
to: f64,
|
||||||
/// The to point.
|
/// The tag.
|
||||||
to: f64,
|
tag: Option<String>,
|
||||||
/// The tag.
|
|
||||||
tag: String,
|
|
||||||
},
|
|
||||||
/// A point.
|
|
||||||
Point(f64),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Draw a line to a point on the x-axis.
|
/// Draw a line to a point on the x-axis.
|
||||||
@ -131,9 +111,9 @@ async fn inner_x_line_to(
|
|||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let from = sketch_group.get_coords_from_paths()?;
|
let from = sketch_group.get_coords_from_paths()?;
|
||||||
|
|
||||||
let line_to_data = match data {
|
let line_to_data = LineToData {
|
||||||
AxisLineToData::PointWithTag { to, tag } => LineToData::PointWithTag { to: [to, from.y], tag },
|
to: [data.to, from.y],
|
||||||
AxisLineToData::Point(data) => LineToData::Point([data, from.y]),
|
tag: data.tag,
|
||||||
};
|
};
|
||||||
|
|
||||||
let new_sketch_group = inner_line_to(line_to_data, sketch_group, args).await?;
|
let new_sketch_group = inner_line_to(line_to_data, sketch_group, args).await?;
|
||||||
@ -160,9 +140,9 @@ async fn inner_y_line_to(
|
|||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let from = sketch_group.get_coords_from_paths()?;
|
let from = sketch_group.get_coords_from_paths()?;
|
||||||
|
|
||||||
let line_to_data = match data {
|
let line_to_data = LineToData {
|
||||||
AxisLineToData::PointWithTag { to, tag } => LineToData::PointWithTag { to: [from.x, to], tag },
|
to: [from.x, data.to],
|
||||||
AxisLineToData::Point(data) => LineToData::Point([from.x, data]),
|
tag: data.tag,
|
||||||
};
|
};
|
||||||
|
|
||||||
let new_sketch_group = inner_line_to(line_to_data, sketch_group, args).await?;
|
let new_sketch_group = inner_line_to(line_to_data, sketch_group, args).await?;
|
||||||
@ -172,17 +152,12 @@ async fn inner_y_line_to(
|
|||||||
/// Data to draw a line.
|
/// Data to draw a line.
|
||||||
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
||||||
#[ts(export)]
|
#[ts(export)]
|
||||||
#[serde(rename_all = "camelCase", untagged)]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub enum LineData {
|
pub struct LineData {
|
||||||
/// A point with a tag.
|
/// The to point.
|
||||||
PointWithTag {
|
to: [f64; 2],
|
||||||
/// The to point.
|
/// The tag.
|
||||||
to: [f64; 2],
|
tag: Option<String>,
|
||||||
/// The tag.
|
|
||||||
tag: String,
|
|
||||||
},
|
|
||||||
/// A point.
|
|
||||||
Point([f64; 2]),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Draw a line.
|
/// Draw a line.
|
||||||
@ -199,10 +174,7 @@ pub async fn line(args: Args) -> Result<MemoryItem, KclError> {
|
|||||||
}]
|
}]
|
||||||
async fn inner_line(data: LineData, sketch_group: Box<SketchGroup>, args: Args) -> Result<Box<SketchGroup>, KclError> {
|
async fn inner_line(data: LineData, sketch_group: Box<SketchGroup>, args: Args) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let from = sketch_group.get_coords_from_paths()?;
|
let from = sketch_group.get_coords_from_paths()?;
|
||||||
let inner_args = match &data {
|
let inner_args = data.to;
|
||||||
LineData::PointWithTag { to, .. } => *to,
|
|
||||||
LineData::Point(to) => *to,
|
|
||||||
};
|
|
||||||
|
|
||||||
let delta = inner_args;
|
let delta = inner_args;
|
||||||
let to = [from.x + inner_args[0], from.y + inner_args[1]];
|
let to = [from.x + inner_args[0], from.y + inner_args[1]];
|
||||||
@ -214,11 +186,7 @@ async fn inner_line(data: LineData, sketch_group: Box<SketchGroup>, args: Args)
|
|||||||
ModelingCmd::ExtendPath {
|
ModelingCmd::ExtendPath {
|
||||||
path: sketch_group.id,
|
path: sketch_group.id,
|
||||||
segment: kittycad::types::PathSegment::Line {
|
segment: kittycad::types::PathSegment::Line {
|
||||||
end: Point3D {
|
end: point3d(delta),
|
||||||
x: delta[0],
|
|
||||||
y: delta[1],
|
|
||||||
z: 0.0,
|
|
||||||
},
|
|
||||||
relative: true,
|
relative: true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@ -229,11 +197,7 @@ async fn inner_line(data: LineData, sketch_group: Box<SketchGroup>, args: Args)
|
|||||||
base: BasePath {
|
base: BasePath {
|
||||||
from: from.into(),
|
from: from.into(),
|
||||||
to,
|
to,
|
||||||
name: if let LineData::PointWithTag { tag, .. } = data {
|
name: data.tag.unwrap_or_default(),
|
||||||
tag.to_string()
|
|
||||||
} else {
|
|
||||||
"".to_string()
|
|
||||||
},
|
|
||||||
geo_meta: GeoMeta {
|
geo_meta: GeoMeta {
|
||||||
id,
|
id,
|
||||||
metadata: args.source_range.into(),
|
metadata: args.source_range.into(),
|
||||||
@ -250,17 +214,12 @@ async fn inner_line(data: LineData, sketch_group: Box<SketchGroup>, args: Args)
|
|||||||
/// Data to draw a line on an axis.
|
/// Data to draw a line on an axis.
|
||||||
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
||||||
#[ts(export)]
|
#[ts(export)]
|
||||||
#[serde(rename_all = "camelCase", untagged)]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub enum AxisLineData {
|
pub struct AxisLineData {
|
||||||
/// The length with a tag.
|
/// The length of the line.
|
||||||
LengthWithTag {
|
length: f64,
|
||||||
/// The length of the line.
|
/// The tag.
|
||||||
length: f64,
|
tag: Option<String>,
|
||||||
/// The tag.
|
|
||||||
tag: String,
|
|
||||||
},
|
|
||||||
/// The length.
|
|
||||||
Length(f64),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Draw a line on the x-axis.
|
/// Draw a line on the x-axis.
|
||||||
@ -280,9 +239,9 @@ async fn inner_x_line(
|
|||||||
sketch_group: Box<SketchGroup>,
|
sketch_group: Box<SketchGroup>,
|
||||||
args: Args,
|
args: Args,
|
||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let line_data = match data {
|
let line_data = LineData {
|
||||||
AxisLineData::LengthWithTag { length, tag } => LineData::PointWithTag { to: [length, 0.0], tag },
|
to: [data.length, 0.0],
|
||||||
AxisLineData::Length(length) => LineData::Point([length, 0.0]),
|
tag: data.tag,
|
||||||
};
|
};
|
||||||
|
|
||||||
let new_sketch_group = inner_line(line_data, sketch_group, args).await?;
|
let new_sketch_group = inner_line(line_data, sketch_group, args).await?;
|
||||||
@ -306,9 +265,9 @@ async fn inner_y_line(
|
|||||||
sketch_group: Box<SketchGroup>,
|
sketch_group: Box<SketchGroup>,
|
||||||
args: Args,
|
args: Args,
|
||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let line_data = match data {
|
let line_data = LineData {
|
||||||
AxisLineData::LengthWithTag { length, tag } => LineData::PointWithTag { to: [0.0, length], tag },
|
to: [0.0, data.length],
|
||||||
AxisLineData::Length(length) => LineData::Point([0.0, length]),
|
tag: data.tag,
|
||||||
};
|
};
|
||||||
|
|
||||||
let new_sketch_group = inner_line(line_data, sketch_group, args).await?;
|
let new_sketch_group = inner_line(line_data, sketch_group, args).await?;
|
||||||
@ -318,28 +277,19 @@ async fn inner_y_line(
|
|||||||
/// Data to draw an angled line.
|
/// Data to draw an angled line.
|
||||||
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
||||||
#[ts(export)]
|
#[ts(export)]
|
||||||
#[serde(rename_all = "camelCase", untagged)]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub enum AngledLineData {
|
pub struct AngledLineData {
|
||||||
/// An angle and length with a tag.
|
/// The angle of the line.
|
||||||
AngleWithTag {
|
angle: f64,
|
||||||
/// The angle of the line.
|
/// The length of the line.
|
||||||
angle: f64,
|
length: f64,
|
||||||
/// The length of the line.
|
/// The tag.
|
||||||
length: f64,
|
tag: Option<String>,
|
||||||
/// The tag.
|
|
||||||
tag: String,
|
|
||||||
},
|
|
||||||
/// An angle and length.
|
|
||||||
AngleAndLength([f64; 2]),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl AngledLineData {
|
impl AngledLineData {
|
||||||
pub fn into_inner_line(self, to: [f64; 2]) -> LineData {
|
pub fn into_inner_line(self, to: [f64; 2]) -> LineData {
|
||||||
if let AngledLineData::AngleWithTag { tag, .. } = self {
|
LineData { to, tag: self.tag }
|
||||||
LineData::PointWithTag { to, tag }
|
|
||||||
} else {
|
|
||||||
LineData::Point(to)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -361,10 +311,7 @@ async fn inner_angled_line(
|
|||||||
args: Args,
|
args: Args,
|
||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let from = sketch_group.get_coords_from_paths()?;
|
let from = sketch_group.get_coords_from_paths()?;
|
||||||
let (angle, length) = match &data {
|
let AngledLineData { angle, length, tag } = data;
|
||||||
AngledLineData::AngleWithTag { angle, length, .. } => (*angle, *length),
|
|
||||||
AngledLineData::AngleAndLength(angle_and_length) => (angle_and_length[0], angle_and_length[1]),
|
|
||||||
};
|
|
||||||
|
|
||||||
//double check me on this one - mike
|
//double check me on this one - mike
|
||||||
let delta: [f64; 2] = [
|
let delta: [f64; 2] = [
|
||||||
@ -381,11 +328,7 @@ async fn inner_angled_line(
|
|||||||
base: BasePath {
|
base: BasePath {
|
||||||
from: from.into(),
|
from: from.into(),
|
||||||
to,
|
to,
|
||||||
name: if let AngledLineData::AngleWithTag { tag, .. } = data {
|
name: tag.unwrap_or_default(),
|
||||||
tag.to_string()
|
|
||||||
} else {
|
|
||||||
"".to_string()
|
|
||||||
},
|
|
||||||
geo_meta: GeoMeta {
|
geo_meta: GeoMeta {
|
||||||
id,
|
id,
|
||||||
metadata: args.source_range.into(),
|
metadata: args.source_range.into(),
|
||||||
@ -398,11 +341,7 @@ async fn inner_angled_line(
|
|||||||
ModelingCmd::ExtendPath {
|
ModelingCmd::ExtendPath {
|
||||||
path: sketch_group.id,
|
path: sketch_group.id,
|
||||||
segment: kittycad::types::PathSegment::Line {
|
segment: kittycad::types::PathSegment::Line {
|
||||||
end: Point3D {
|
end: point3d(delta),
|
||||||
x: delta[0],
|
|
||||||
y: delta[1],
|
|
||||||
z: 0.0,
|
|
||||||
},
|
|
||||||
relative,
|
relative,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@ -431,12 +370,7 @@ async fn inner_angled_line_of_x_length(
|
|||||||
sketch_group: Box<SketchGroup>,
|
sketch_group: Box<SketchGroup>,
|
||||||
args: Args,
|
args: Args,
|
||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let (angle, length) = match &data {
|
let to = get_y_component(Angle::from_degrees(data.angle), data.length);
|
||||||
AngledLineData::AngleWithTag { angle, length, .. } => (*angle, *length),
|
|
||||||
AngledLineData::AngleAndLength(angle_and_length) => (angle_and_length[0], angle_and_length[1]),
|
|
||||||
};
|
|
||||||
|
|
||||||
let to = get_y_component(Angle::from_degrees(angle), length);
|
|
||||||
|
|
||||||
let new_sketch_group = inner_line(data.into_inner_line(to.into()), sketch_group, args).await?;
|
let new_sketch_group = inner_line(data.into_inner_line(to.into()), sketch_group, args).await?;
|
||||||
|
|
||||||
@ -446,28 +380,20 @@ async fn inner_angled_line_of_x_length(
|
|||||||
/// Data to draw an angled line to a point.
|
/// Data to draw an angled line to a point.
|
||||||
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
||||||
#[ts(export)]
|
#[ts(export)]
|
||||||
#[serde(rename_all = "camelCase", untagged)]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub enum AngledLineToData {
|
pub struct AngledLineToData {
|
||||||
/// An angle and point with a tag.
|
/// The angle of the line.
|
||||||
AngleWithTag {
|
angle: f64,
|
||||||
/// The angle of the line.
|
/// The point to draw to.
|
||||||
angle: f64,
|
to: f64,
|
||||||
/// The point to draw to.
|
/// The tag.
|
||||||
to: f64,
|
tag: Option<String>,
|
||||||
/// The tag.
|
|
||||||
tag: String,
|
|
||||||
},
|
|
||||||
/// An angle and point to draw to.
|
|
||||||
AngleAndPoint([f64; 2]),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl AngledLineToData {
|
impl AngledLineToData {
|
||||||
pub fn into_inner_line(self, x_to: f64, y_to: f64) -> LineToData {
|
pub fn into_inner_line(self, x_to: f64, y_to: f64) -> LineToData {
|
||||||
if let AngledLineToData::AngleWithTag { tag, .. } = self {
|
let tag = self.tag;
|
||||||
LineToData::PointWithTag { to: [x_to, y_to], tag }
|
LineToData { to: [x_to, y_to], tag }
|
||||||
} else {
|
|
||||||
LineToData::Point([x_to, y_to])
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -489,10 +415,7 @@ async fn inner_angled_line_to_x(
|
|||||||
args: Args,
|
args: Args,
|
||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let from = sketch_group.get_coords_from_paths()?;
|
let from = sketch_group.get_coords_from_paths()?;
|
||||||
let (angle, x_to) = match &data {
|
let (angle, x_to) = (data.angle, data.to);
|
||||||
AngledLineToData::AngleWithTag { angle, to, .. } => (*angle, *to),
|
|
||||||
AngledLineToData::AngleAndPoint(angle_and_to) => (angle_and_to[0], angle_and_to[1]),
|
|
||||||
};
|
|
||||||
|
|
||||||
let x_component = x_to - from.x;
|
let x_component = x_to - from.x;
|
||||||
let y_component = x_component * f64::tan(angle.to_radians());
|
let y_component = x_component * f64::tan(angle.to_radians());
|
||||||
@ -520,10 +443,7 @@ async fn inner_angled_line_of_y_length(
|
|||||||
sketch_group: Box<SketchGroup>,
|
sketch_group: Box<SketchGroup>,
|
||||||
args: Args,
|
args: Args,
|
||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let (angle, length) = match &data {
|
let (angle, length) = (data.angle, data.length);
|
||||||
AngledLineData::AngleWithTag { angle, length, .. } => (*angle, *length),
|
|
||||||
AngledLineData::AngleAndLength(angle_and_length) => (angle_and_length[0], angle_and_length[1]),
|
|
||||||
};
|
|
||||||
|
|
||||||
let to = get_x_component(Angle::from_degrees(angle), length);
|
let to = get_x_component(Angle::from_degrees(angle), length);
|
||||||
|
|
||||||
@ -550,10 +470,7 @@ async fn inner_angled_line_to_y(
|
|||||||
args: Args,
|
args: Args,
|
||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let from = sketch_group.get_coords_from_paths()?;
|
let from = sketch_group.get_coords_from_paths()?;
|
||||||
let (angle, y_to) = match &data {
|
let (angle, y_to) = (data.angle, data.to);
|
||||||
AngledLineToData::AngleWithTag { angle, to, .. } => (*angle, *to),
|
|
||||||
AngledLineToData::AngleAndPoint(angle_and_to) => (angle_and_to[0], angle_and_to[1]),
|
|
||||||
};
|
|
||||||
|
|
||||||
let y_component = y_to - from.y;
|
let y_component = y_to - from.y;
|
||||||
let x_component = y_component / f64::tan(angle.to_radians());
|
let x_component = y_component / f64::tan(angle.to_radians());
|
||||||
@ -616,10 +533,9 @@ async fn inner_angled_line_that_intersects(
|
|||||||
from,
|
from,
|
||||||
);
|
);
|
||||||
|
|
||||||
let line_to_data = if let Some(tag) = data.tag {
|
let line_to_data = LineToData {
|
||||||
LineToData::PointWithTag { to: to.into(), tag }
|
to: to.into(),
|
||||||
} else {
|
tag: data.tag,
|
||||||
LineToData::Point(to.into())
|
|
||||||
};
|
};
|
||||||
|
|
||||||
let new_sketch_group = inner_line_to(line_to_data, sketch_group, args).await?;
|
let new_sketch_group = inner_line_to(line_to_data, sketch_group, args).await?;
|
||||||
@ -830,10 +746,7 @@ pub async fn start_profile_at(args: Args) -> Result<MemoryItem, KclError> {
|
|||||||
name = "startProfileAt",
|
name = "startProfileAt",
|
||||||
}]
|
}]
|
||||||
async fn inner_start_profile_at(data: LineData, plane: Box<Plane>, args: Args) -> Result<Box<SketchGroup>, KclError> {
|
async fn inner_start_profile_at(data: LineData, plane: Box<Plane>, args: Args) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let to = match &data {
|
let to = data.to;
|
||||||
LineData::PointWithTag { to, .. } => *to,
|
|
||||||
LineData::Point(to) => *to,
|
|
||||||
};
|
|
||||||
|
|
||||||
let id = uuid::Uuid::new_v4();
|
let id = uuid::Uuid::new_v4();
|
||||||
let path_id = uuid::Uuid::new_v4();
|
let path_id = uuid::Uuid::new_v4();
|
||||||
@ -843,11 +756,7 @@ async fn inner_start_profile_at(data: LineData, plane: Box<Plane>, args: Args) -
|
|||||||
id,
|
id,
|
||||||
ModelingCmd::MovePathPen {
|
ModelingCmd::MovePathPen {
|
||||||
path: path_id,
|
path: path_id,
|
||||||
to: Point3D {
|
to: point3d(to),
|
||||||
x: to[0],
|
|
||||||
y: to[1],
|
|
||||||
z: 0.0,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
.await?;
|
.await?;
|
||||||
@ -855,11 +764,7 @@ async fn inner_start_profile_at(data: LineData, plane: Box<Plane>, args: Args) -
|
|||||||
let current_path = BasePath {
|
let current_path = BasePath {
|
||||||
from: to,
|
from: to,
|
||||||
to,
|
to,
|
||||||
name: if let LineData::PointWithTag { tag, .. } = data {
|
name: data.tag.unwrap_or_default(),
|
||||||
tag.to_string()
|
|
||||||
} else {
|
|
||||||
"".to_string()
|
|
||||||
},
|
|
||||||
geo_meta: GeoMeta {
|
geo_meta: GeoMeta {
|
||||||
id,
|
id,
|
||||||
metadata: args.source_range.into(),
|
metadata: args.source_range.into(),
|
||||||
@ -943,16 +848,7 @@ pub enum ArcData {
|
|||||||
/// The radius.
|
/// The radius.
|
||||||
radius: f64,
|
radius: f64,
|
||||||
/// The tag.
|
/// The tag.
|
||||||
tag: String,
|
tag: Option<String>,
|
||||||
},
|
|
||||||
/// Angles and radius.
|
|
||||||
AnglesAndRadius {
|
|
||||||
/// The start angle.
|
|
||||||
angle_start: f64,
|
|
||||||
/// The end angle.
|
|
||||||
angle_end: f64,
|
|
||||||
/// The radius.
|
|
||||||
radius: f64,
|
|
||||||
},
|
},
|
||||||
/// Center, to and radius with a tag.
|
/// Center, to and radius with a tag.
|
||||||
CenterToRadiusWithTag {
|
CenterToRadiusWithTag {
|
||||||
@ -963,16 +859,7 @@ pub enum ArcData {
|
|||||||
/// The radius.
|
/// The radius.
|
||||||
radius: f64,
|
radius: f64,
|
||||||
/// The tag.
|
/// The tag.
|
||||||
tag: String,
|
tag: Option<String>,
|
||||||
},
|
|
||||||
/// Center, to and radius.
|
|
||||||
CenterToRadius {
|
|
||||||
/// The center.
|
|
||||||
center: [f64; 2],
|
|
||||||
/// The to point.
|
|
||||||
to: [f64; 2],
|
|
||||||
/// The radius.
|
|
||||||
radius: f64,
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1003,24 +890,10 @@ async fn inner_arc(data: ArcData, sketch_group: Box<SketchGroup>, args: Args) ->
|
|||||||
let (center, end) = arc_center_and_end(from, a_start, a_end, *radius);
|
let (center, end) = arc_center_and_end(from, a_start, a_end, *radius);
|
||||||
(center, a_start, a_end, *radius, end)
|
(center, a_start, a_end, *radius, end)
|
||||||
}
|
}
|
||||||
ArcData::AnglesAndRadius {
|
|
||||||
angle_start,
|
|
||||||
angle_end,
|
|
||||||
radius,
|
|
||||||
} => {
|
|
||||||
let a_start = Angle::from_degrees(*angle_start);
|
|
||||||
let a_end = Angle::from_degrees(*angle_end);
|
|
||||||
let (center, end) = arc_center_and_end(from, a_start, a_end, *radius);
|
|
||||||
(center, a_start, a_end, *radius, end)
|
|
||||||
}
|
|
||||||
ArcData::CenterToRadiusWithTag { center, to, radius, .. } => {
|
ArcData::CenterToRadiusWithTag { center, to, radius, .. } => {
|
||||||
let (angle_start, angle_end) = arc_angles(from, center.into(), to.into(), *radius, args.source_range)?;
|
let (angle_start, angle_end) = arc_angles(from, center.into(), to.into(), *radius, args.source_range)?;
|
||||||
(center.into(), angle_start, angle_end, *radius, to.into())
|
(center.into(), angle_start, angle_end, *radius, to.into())
|
||||||
}
|
}
|
||||||
ArcData::CenterToRadius { center, to, radius } => {
|
|
||||||
let (angle_start, angle_end) = arc_angles(from, center.into(), to.into(), *radius, args.source_range)?;
|
|
||||||
(center.into(), angle_start, angle_end, *radius, to.into())
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
let id = uuid::Uuid::new_v4();
|
let id = uuid::Uuid::new_v4();
|
||||||
@ -1047,10 +920,8 @@ async fn inner_arc(data: ArcData, sketch_group: Box<SketchGroup>, args: Args) ->
|
|||||||
from: from.into(),
|
from: from.into(),
|
||||||
to: end.into(),
|
to: end.into(),
|
||||||
name: match data {
|
name: match data {
|
||||||
ArcData::AnglesAndRadiusWithTag { tag, .. } => tag.to_string(),
|
ArcData::AnglesAndRadiusWithTag { tag, .. } => tag.unwrap_or_default(),
|
||||||
ArcData::AnglesAndRadius { .. } => "".to_string(),
|
ArcData::CenterToRadiusWithTag { tag, .. } => tag.unwrap_or_default(),
|
||||||
ArcData::CenterToRadiusWithTag { tag, .. } => tag.to_string(),
|
|
||||||
ArcData::CenterToRadius { .. } => "".to_string(),
|
|
||||||
},
|
},
|
||||||
geo_meta: GeoMeta {
|
geo_meta: GeoMeta {
|
||||||
id,
|
id,
|
||||||
@ -1082,10 +953,8 @@ pub enum TangentialArcData {
|
|||||||
/// Where the arc should end. Must lie in the same plane as the current path pen position. Must not be colinear with current path pen position.
|
/// Where the arc should end. Must lie in the same plane as the current path pen position. Must not be colinear with current path pen position.
|
||||||
to: [f64; 2],
|
to: [f64; 2],
|
||||||
/// The tag.
|
/// The tag.
|
||||||
tag: String,
|
tag: Option<String>,
|
||||||
},
|
},
|
||||||
/// A point where the arc should end. Must lie in the same plane as the current path pen position. Must not be colinear with current path pen position.
|
|
||||||
Point([f64; 2]),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Draw a tangential arc.
|
/// Draw a tangential arc.
|
||||||
@ -1135,11 +1004,6 @@ async fn inner_tangential_arc(
|
|||||||
TangentialArcData::PointWithTag { to, .. } => {
|
TangentialArcData::PointWithTag { to, .. } => {
|
||||||
args.send_modeling_cmd(id, tan_arc_to(&sketch_group, to)).await?;
|
args.send_modeling_cmd(id, tan_arc_to(&sketch_group, to)).await?;
|
||||||
|
|
||||||
*to
|
|
||||||
}
|
|
||||||
TangentialArcData::Point(to) => {
|
|
||||||
args.send_modeling_cmd(id, tan_arc_to(&sketch_group, to)).await?;
|
|
||||||
|
|
||||||
*to
|
*to
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -1169,11 +1033,7 @@ fn tan_arc_to(sketch_group: &SketchGroup, to: &[f64; 2]) -> ModelingCmd {
|
|||||||
path: sketch_group.id,
|
path: sketch_group.id,
|
||||||
segment: kittycad::types::PathSegment::TangentialArcTo {
|
segment: kittycad::types::PathSegment::TangentialArcTo {
|
||||||
angle_snap_increment: None,
|
angle_snap_increment: None,
|
||||||
to: Point3D {
|
to: point3d(*to),
|
||||||
x: to[0],
|
|
||||||
y: to[1],
|
|
||||||
z: 0.0,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1181,17 +1041,12 @@ fn tan_arc_to(sketch_group: &SketchGroup, to: &[f64; 2]) -> ModelingCmd {
|
|||||||
/// Data to draw a tangential arc to a specific point.
|
/// Data to draw a tangential arc to a specific point.
|
||||||
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, JsonSchema, ts_rs::TS)]
|
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, JsonSchema, ts_rs::TS)]
|
||||||
#[ts(export)]
|
#[ts(export)]
|
||||||
#[serde(rename_all = "camelCase", untagged)]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub enum TangentialArcToData {
|
pub struct TangentialArcToData {
|
||||||
/// A point with a tag.
|
/// Where the arc should end. Must lie in the same plane as the current path pen position. Must not be colinear with current path pen position.
|
||||||
PointWithTag {
|
to: [f64; 2],
|
||||||
/// Where the arc should end. Must lie in the same plane as the current path pen position. Must not be colinear with current path pen position.
|
/// The tag.
|
||||||
to: [f64; 2],
|
tag: Option<String>,
|
||||||
/// The tag.
|
|
||||||
tag: String,
|
|
||||||
},
|
|
||||||
/// A point where the arc should end. Must lie in the same plane as the current path pen position. Must not be colinear with current path pen position.
|
|
||||||
Point([f64; 2]),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Draw a tangential arc to a specific point.
|
/// Draw a tangential arc to a specific point.
|
||||||
@ -1212,10 +1067,8 @@ async fn inner_tangential_arc_to(
|
|||||||
args: Args,
|
args: Args,
|
||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let from: Point2d = sketch_group.get_coords_from_paths()?;
|
let from: Point2d = sketch_group.get_coords_from_paths()?;
|
||||||
let to = match &data {
|
let to = data.to;
|
||||||
TangentialArcToData::PointWithTag { to, .. } => to,
|
let name = data.tag.unwrap_or_default().to_owned();
|
||||||
TangentialArcToData::Point(to) => to,
|
|
||||||
};
|
|
||||||
|
|
||||||
let delta = [to[0] - from.x, to[1] - from.y];
|
let delta = [to[0] - from.x, to[1] - from.y];
|
||||||
let id = uuid::Uuid::new_v4();
|
let id = uuid::Uuid::new_v4();
|
||||||
@ -1224,12 +1077,8 @@ async fn inner_tangential_arc_to(
|
|||||||
let current_path = Path::ToPoint {
|
let current_path = Path::ToPoint {
|
||||||
base: BasePath {
|
base: BasePath {
|
||||||
from: from.into(),
|
from: from.into(),
|
||||||
to: *to,
|
to,
|
||||||
name: if let TangentialArcToData::PointWithTag { tag, .. } = data {
|
name,
|
||||||
tag.to_string()
|
|
||||||
} else {
|
|
||||||
"".to_string()
|
|
||||||
},
|
|
||||||
geo_meta: GeoMeta {
|
geo_meta: GeoMeta {
|
||||||
id,
|
id,
|
||||||
metadata: args.source_range.into(),
|
metadata: args.source_range.into(),
|
||||||
@ -1246,28 +1095,16 @@ async fn inner_tangential_arc_to(
|
|||||||
/// Data to draw a bezier curve.
|
/// Data to draw a bezier curve.
|
||||||
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq, ts_rs::TS, JsonSchema)]
|
||||||
#[ts(export)]
|
#[ts(export)]
|
||||||
#[serde(rename_all = "camelCase", untagged)]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub enum BezierData {
|
pub struct BezierData {
|
||||||
/// Points with a tag.
|
/// The to point.
|
||||||
PointsWithTag {
|
to: [f64; 2],
|
||||||
/// The to point.
|
/// The first control point.
|
||||||
to: [f64; 2],
|
control1: [f64; 2],
|
||||||
/// The first control point.
|
/// The second control point.
|
||||||
control1: [f64; 2],
|
control2: [f64; 2],
|
||||||
/// The second control point.
|
/// The tag.
|
||||||
control2: [f64; 2],
|
tag: Option<String>,
|
||||||
/// The tag.
|
|
||||||
tag: String,
|
|
||||||
},
|
|
||||||
/// Points.
|
|
||||||
Points {
|
|
||||||
/// The to point.
|
|
||||||
to: [f64; 2],
|
|
||||||
/// The first control point.
|
|
||||||
control1: [f64; 2],
|
|
||||||
/// The second control point.
|
|
||||||
control2: [f64; 2],
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Draw a bezier curve.
|
/// Draw a bezier curve.
|
||||||
@ -1289,12 +1126,13 @@ async fn inner_bezier_curve(
|
|||||||
) -> Result<Box<SketchGroup>, KclError> {
|
) -> Result<Box<SketchGroup>, KclError> {
|
||||||
let from = sketch_group.get_coords_from_paths()?;
|
let from = sketch_group.get_coords_from_paths()?;
|
||||||
|
|
||||||
let (to, control1, control2) = match &data {
|
let BezierData {
|
||||||
BezierData::PointsWithTag {
|
to,
|
||||||
to, control1, control2, ..
|
control1,
|
||||||
} => (to, control1, control2),
|
control2,
|
||||||
BezierData::Points { to, control1, control2 } => (to, control1, control2),
|
tag,
|
||||||
};
|
} = data;
|
||||||
|
let name = tag.unwrap_or_default();
|
||||||
|
|
||||||
let relative = true;
|
let relative = true;
|
||||||
let delta = to;
|
let delta = to;
|
||||||
@ -1307,21 +1145,9 @@ async fn inner_bezier_curve(
|
|||||||
ModelingCmd::ExtendPath {
|
ModelingCmd::ExtendPath {
|
||||||
path: sketch_group.id,
|
path: sketch_group.id,
|
||||||
segment: kittycad::types::PathSegment::Bezier {
|
segment: kittycad::types::PathSegment::Bezier {
|
||||||
control1: Point3D {
|
control1: point3d(control1),
|
||||||
x: control1[0],
|
control2: point3d(control2),
|
||||||
y: control1[1],
|
end: point3d(delta),
|
||||||
z: 0.0,
|
|
||||||
},
|
|
||||||
control2: Point3D {
|
|
||||||
x: control2[0],
|
|
||||||
y: control2[1],
|
|
||||||
z: 0.0,
|
|
||||||
},
|
|
||||||
end: Point3D {
|
|
||||||
x: delta[0],
|
|
||||||
y: delta[1],
|
|
||||||
z: 0.0,
|
|
||||||
},
|
|
||||||
relative,
|
relative,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@ -1332,11 +1158,7 @@ async fn inner_bezier_curve(
|
|||||||
base: BasePath {
|
base: BasePath {
|
||||||
from: from.into(),
|
from: from.into(),
|
||||||
to,
|
to,
|
||||||
name: if let BezierData::PointsWithTag { tag, .. } = data {
|
name,
|
||||||
tag.to_string()
|
|
||||||
} else {
|
|
||||||
"".to_string()
|
|
||||||
},
|
|
||||||
geo_meta: GeoMeta {
|
geo_meta: GeoMeta {
|
||||||
id,
|
id,
|
||||||
metadata: args.source_range.into(),
|
metadata: args.source_range.into(),
|
||||||
@ -1394,6 +1216,10 @@ async fn inner_hole(
|
|||||||
Ok(sketch_group)
|
Ok(sketch_group)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn point3d([x, y]: [f64; 2]) -> Point3D {
|
||||||
|
Point3D { x, y, z: 0.0 }
|
||||||
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
|
|
||||||
@ -1403,21 +1229,30 @@ mod tests {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_deserialize_line_data() {
|
fn test_deserialize_line_data() {
|
||||||
let data = LineData::Point([0.0, 1.0]);
|
let data = LineData {
|
||||||
|
to: [0.0, 1.0],
|
||||||
|
tag: None,
|
||||||
|
};
|
||||||
let mut str_json = serde_json::to_string(&data).unwrap();
|
let mut str_json = serde_json::to_string(&data).unwrap();
|
||||||
assert_eq!(str_json, "[0.0,1.0]");
|
assert_eq!(str_json, "[0.0,1.0]");
|
||||||
|
|
||||||
str_json = "[0, 1]".to_string();
|
str_json = "[0, 1]".to_string();
|
||||||
let data: LineData = serde_json::from_str(&str_json).unwrap();
|
let data: LineData = serde_json::from_str(&str_json).unwrap();
|
||||||
assert_eq!(data, LineData::Point([0.0, 1.0]));
|
assert_eq!(
|
||||||
|
data,
|
||||||
|
LineData {
|
||||||
|
to: [0.0, 1.0],
|
||||||
|
tag: None
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
str_json = "{ \"to\": [0.0, 1.0], \"tag\": \"thing\" }".to_string();
|
str_json = "{ \"to\": [0.0, 1.0], \"tag\": \"thing\" }".to_string();
|
||||||
let data: LineData = serde_json::from_str(&str_json).unwrap();
|
let data: LineData = serde_json::from_str(&str_json).unwrap();
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
data,
|
data,
|
||||||
LineData::PointWithTag {
|
LineData {
|
||||||
to: [0.0, 1.0],
|
to: [0.0, 1.0],
|
||||||
tag: "thing".to_string()
|
tag: Some("thing".to_string()),
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user