* Change to unzip * Download kcl-samples as zip to public dir * Fix fetch:samples, e2e electron still not working * Change error message to be clearer * Refactor so that input and output directories of sim tests can be different * Add kcl samples test implementation * Update output since adding kcl_samples tests * Update kcl-samples branch * Fix git-ignore pattern to only apply to the root * Fix yarn install and yarn fetch:samples to work the first time * Remove unneeded exists check * Change to use kcl-samples in public directory * Add kcl-samples * Update output since updating kcl-samples * Update output files * Change to not fetch samples during yarn install * Update output after merge * Ignore kcl-samples in codespell * WIP: Don't run e2e if only kcl-samples changed * Conditionally run cargo tests * Fix to round floating point values in program memory arrays * Update output since merge and rounding numbers in memory * Fix memory redaction for floating point to find more values * Fix float redaction pattern * Update output since rounding floating point numbers * Add center to floating point pattern * Fix trigger to use picomatch syntax * Update output since rounding center * Remove kcl-samples github workflows * Enable Rust backtrace * Update output after re-running * Update output after changing order of post-extrude commands * Fix to have deterministic order of commands * Update output after reverting ordering changes * Update kcl-samples * Update output after updating samples * Fix error messages to show the names of all samples that failed * Change cargo test command to match current one * Update kcl-samples * Update output since updating kcl-samples * Add generate manifest workflow and yarn script * Fix error check to actually work * Change util function to be what we actually need * Move new files after merge * Fix paths since directory move * Add dependabot updates for kcl-samples * Add GitHub workflow to make PR to kcl-samples repo * Add GitHub workflow to check kcl-samples header comments * Fix worfklow to change to the right directory * Add auto-commit simulation test output changes * Add permissions to workflows * Fix to run git commit step * Install just if needed * Fix directory of justfile * Add installation of cargo-insta * Fix to use underscore * Fix to allow just command failure * Change to always install CLI tools and cache them * Trying to fix overwrite failing * Combine commands * Change reviewer * Change to PR targeting the next branch * Change git commands to not do unnecessary fetch * Comment out trigger for creating a PR * Update kcl-samples from next branch * Update outputs after kcl-samples change * Fix to use bash pipefail * Add rust backtrace * Print full env from sim tests * Change command to use long option name * Fix to use ci profile even when calling through just * Add INSTA_UPDATE=always * Fix git push by using an app token on checkout * Add comments * Fix to use bash options * Change to echo when no changes are found * Fix so that kcl-samples updates don't trigger full run * Fix paths to reflect new crate location * Fix path detection * Fix e2e job to ignore kcl_samples simulation test output * Fix the fetch logic for the KCL samples after vendoring (#5661) Fixes the last 2 E2E tests for #5460. --------- Co-authored-by: Pierre Jacquier <pierre@zoo.dev> Co-authored-by: Pierre Jacquier <pierrejacquier39@gmail.com> Co-authored-by: Frank Noirot <frank@zoo.dev>
197 lines
5.5 KiB
Plaintext
197 lines
5.5 KiB
Plaintext
// Enclosure
|
|
// An enclosure body and sealing lid for storing items
|
|
|
|
// Set units
|
|
@settings(defaultLengthUnit = mm)
|
|
|
|
length = 175
|
|
width = 125
|
|
height = 70
|
|
wallThickness = 3
|
|
holeDia = 4
|
|
|
|
// Model a box with base enclosure dimensions
|
|
sketch001 = startSketchOn('XY')
|
|
|> startProfileAt([0, 0], %)
|
|
|> angledLine([0, width], %, $rectangleSegmentA001)
|
|
|> angledLine([
|
|
segAng(rectangleSegmentA001) + 90,
|
|
length
|
|
], %, $rectangleSegmentB001)
|
|
|> angledLine([
|
|
segAng(rectangleSegmentA001),
|
|
-segLen(rectangleSegmentA001)
|
|
], %, $rectangleSegmentC001)
|
|
|> line(endAbsolute = [profileStartX(%), profileStartY(%)], tag = $rectangleSegmentD001)
|
|
|> close()
|
|
extrude001 = extrude(sketch001, length = height)
|
|
|> fillet(
|
|
radius = wallThickness * 4,
|
|
tags = [
|
|
getNextAdjacentEdge(rectangleSegmentA001),
|
|
getNextAdjacentEdge(rectangleSegmentB001),
|
|
getNextAdjacentEdge(rectangleSegmentC001),
|
|
getNextAdjacentEdge(rectangleSegmentD001)
|
|
]
|
|
)
|
|
|
|
// Apply a shell to the enclosure base to create the internal storage
|
|
|> shell(
|
|
faces = ["end"],
|
|
thickness = wallThickness
|
|
)
|
|
|
|
// Define a function to create the internal structure to secure a fastener at each corner
|
|
fn function001(originStart) {
|
|
// Create a plane to sketch on shell interior
|
|
plane001 = {
|
|
plane = {
|
|
origin = [0.0, 0.0, wallThickness],
|
|
xAxis = [1.0, 0.0, 0.0],
|
|
yAxis = [0.0, 1.0, 0.0],
|
|
zAxis = [0.0, 0.0, 1.0]
|
|
}
|
|
}
|
|
|
|
// Create a pillar with a fasterner hole at the center
|
|
sketch002 = startSketchOn(plane001)
|
|
|> circle(
|
|
center = [originStart[0], originStart[1]],
|
|
radius = holeDia + wallThickness
|
|
)
|
|
|> hole(circle(
|
|
center = [originStart[0], originStart[1]],
|
|
radius = holeDia
|
|
), %)
|
|
extrude002 = extrude(sketch002, length = height - wallThickness)
|
|
|
|
return extrude002
|
|
}
|
|
|
|
// Place the internal pillar at each corner
|
|
function001([
|
|
wallThickness * 3 + holeDia,
|
|
wallThickness * 3 + holeDia
|
|
])
|
|
function001([
|
|
wallThickness * 3 + holeDia,
|
|
length - (wallThickness * 3 + holeDia)
|
|
])
|
|
function001([
|
|
width - (wallThickness * 3 + holeDia),
|
|
wallThickness * 3 + holeDia
|
|
])
|
|
function001([
|
|
width - (wallThickness * 3 + holeDia),
|
|
length - (wallThickness * 3 + holeDia)
|
|
])
|
|
|
|
// Define lid position and outer surface
|
|
sketch003 = startSketchOn('XY')
|
|
|> startProfileAt([width * 1.2, 0], %)
|
|
|> angledLine([0, width], %, $rectangleSegmentA002)
|
|
|> angledLine([
|
|
segAng(rectangleSegmentA001) + 90,
|
|
length
|
|
], %, $rectangleSegmentB002)
|
|
|> angledLine([
|
|
segAng(rectangleSegmentA001),
|
|
-segLen(rectangleSegmentA001)
|
|
], %, $rectangleSegmentC002)
|
|
|> line(endAbsolute = [profileStartX(%), profileStartY(%)], tag = $rectangleSegmentD002)
|
|
|> close()
|
|
|> hole(circle(
|
|
center = [
|
|
width * 1.2 + wallThickness * 3 + holeDia,
|
|
wallThickness * 3 + holeDia
|
|
],
|
|
radius = holeDia
|
|
), %)
|
|
|> hole(circle(
|
|
center = [
|
|
width * 1.2 + wallThickness * 3 + holeDia,
|
|
length - (wallThickness * 3 + holeDia)
|
|
],
|
|
radius = holeDia
|
|
), %)
|
|
|> hole(circle(
|
|
center = [
|
|
width * 2.2 - (wallThickness * 3 + holeDia),
|
|
wallThickness * 3 + holeDia
|
|
],
|
|
radius = holeDia
|
|
), %)
|
|
|> hole(circle(
|
|
center = [
|
|
width * 2.2 - (wallThickness * 3 + holeDia),
|
|
length - (wallThickness * 3 + holeDia)
|
|
],
|
|
radius = holeDia
|
|
), %)
|
|
extrude003 = extrude(sketch003, length = wallThickness)
|
|
|> fillet(
|
|
radius = wallThickness * 4,
|
|
tags = [
|
|
getNextAdjacentEdge(rectangleSegmentA002),
|
|
getNextAdjacentEdge(rectangleSegmentB002),
|
|
getNextAdjacentEdge(rectangleSegmentC002),
|
|
getNextAdjacentEdge(rectangleSegmentD002)
|
|
]
|
|
)
|
|
|
|
// Define lid inner and sealing surfaces
|
|
sketch004 = startSketchOn(extrude003, 'END')
|
|
|> startProfileAt([
|
|
width * 1.2 + wallThickness,
|
|
wallThickness
|
|
], %)
|
|
|> angledLine([0, width - (2 * wallThickness)], %, $rectangleSegmentA003)
|
|
|> angledLine([
|
|
segAng(rectangleSegmentA003) + 90,
|
|
length - (2 * wallThickness)
|
|
], %, $rectangleSegmentB003)
|
|
|> angledLine([
|
|
segAng(rectangleSegmentA003),
|
|
-segLen(rectangleSegmentA003)
|
|
], %, $rectangleSegmentC003)
|
|
|> line(endAbsolute = [profileStartX(%), profileStartY(%)], tag = $rectangleSegmentD003)
|
|
|> close()
|
|
|> hole(circle(
|
|
center = [
|
|
width * 1.2 + wallThickness * 3 + holeDia,
|
|
wallThickness * 3 + holeDia
|
|
],
|
|
radius = holeDia + wallThickness
|
|
), %)
|
|
|> hole(circle(
|
|
center = [
|
|
width * 1.2 + wallThickness * 3 + holeDia,
|
|
length - (wallThickness * 3 + holeDia)
|
|
],
|
|
radius = holeDia + wallThickness
|
|
), %)
|
|
|> hole(circle(
|
|
center = [
|
|
width * 2.2 - (wallThickness * 3 + holeDia),
|
|
wallThickness * 3 + holeDia
|
|
],
|
|
radius = holeDia + wallThickness
|
|
), %)
|
|
|> hole(circle(
|
|
center = [
|
|
width * 2.2 - (wallThickness * 3 + holeDia),
|
|
length - (wallThickness * 3 + holeDia)
|
|
],
|
|
radius = holeDia + wallThickness
|
|
), %)
|
|
extrude004 = extrude(sketch004, length = wallThickness)
|
|
|> fillet(
|
|
radius = wallThickness * 3,
|
|
tags = [
|
|
getNextAdjacentEdge(rectangleSegmentA003),
|
|
getNextAdjacentEdge(rectangleSegmentB003),
|
|
getNextAdjacentEdge(rectangleSegmentC003),
|
|
getNextAdjacentEdge(rectangleSegmentD003)
|
|
]
|
|
)
|