Preparing for the removal of positional functions from the language. The first big step is to change all our KCL code examples, test code, public samples etc to all use keyword functions. Apologies for how large this PR is. Most of it is: - Changing example KCL that defined its own functions, so the functions now use keyword arguments rather than positional arguments. E.g. change `cube([20, 20])` to be `cube(center = [20, 20])`. - Some parts of the code assumed positional code and didn't handle keyword calls, e.g. the linter would only check for positional calls to startSketchOn. Now they should work with either positional or keyword. - Update all the artifacts This does _not_ remove support for positional calls. That will be in a follow-up PR.
		
			
				
	
	
		
			80 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| ---
 | |
| source: kcl-lib/src/simulation_tests.rs
 | |
| description: Result of unparsing fillet-and-shell.kcl
 | |
| ---
 | |
| rpizWidth = 30
 | |
| rpizLength = 65
 | |
| 
 | |
| caseThickness = 1
 | |
| 
 | |
| border = 4
 | |
| 
 | |
| screwHeight = 4
 | |
| 
 | |
| caseWidth = rpizWidth + border * 2
 | |
| caseLength = rpizLength + border * 2
 | |
| caseHeight = 8
 | |
| 
 | |
| widthBetweenScrews = 23
 | |
| lengthBetweenScrews = 29 * 2
 | |
| 
 | |
| miniHdmiDistance = 12.4
 | |
| microUsb1Distance = 41.4
 | |
| microUsb2Distance = 54
 | |
| 
 | |
| miniHdmiWidth = 11.2
 | |
| microUsbWidth = 7.4
 | |
| connectorPadding = 4
 | |
| 
 | |
| miniHdmiHole = startSketchOn(XY)
 | |
|   |> startProfile(at = [
 | |
|        0,
 | |
|        border + miniHdmiDistance - (miniHdmiWidth / 2)
 | |
|      ])
 | |
|   |> line(endAbsolute = [
 | |
|        0,
 | |
|        border + miniHdmiDistance + miniHdmiWidth / 2
 | |
|      ])
 | |
|   |> line(endAbsolute = [
 | |
|        1,
 | |
|        border + miniHdmiDistance + miniHdmiWidth / 2
 | |
|      ])
 | |
|   |> line(endAbsolute = [
 | |
|        1,
 | |
|        border + miniHdmiDistance - (miniHdmiWidth / 2)
 | |
|      ])
 | |
|   |> close(%)
 | |
| 
 | |
| case = startSketchOn(XY)
 | |
|   |> startProfile(at = [0, 0])
 | |
|   |> line(endAbsolute = [caseWidth, 0], tag = $edge1)
 | |
|   |> line(endAbsolute = [caseWidth, caseLength], tag = $edge2)
 | |
|   |> line(endAbsolute = [0, caseLength], tag = $edge3)
 | |
|   |> close(tag = $edge4)
 | |
|   |> extrude(length = caseHeight)
 | |
|   |> fillet(
 | |
|        radius = 1,
 | |
|        tags = [
 | |
|          getNextAdjacentEdge(edge1),
 | |
|          getNextAdjacentEdge(edge2),
 | |
|          getNextAdjacentEdge(edge3),
 | |
|          getNextAdjacentEdge(edge4)
 | |
|        ],
 | |
|      )
 | |
| 
 | |
| fn m25Screw(x, y, height) {
 | |
|   screw = startSketchOn(XY)
 | |
|     |> startProfile(at = [0, 0])
 | |
|     |> circle(center = [x, y], radius = 2.5)
 | |
|     |> subtract2d(tool = circle(center = [x, y], radius = 1.25))
 | |
|     |> extrude(length = height)
 | |
|   return screw
 | |
| }
 | |
| 
 | |
| m25Screw(x = border + rpizWidth / 2 - (widthBetweenScrews / 2), y = 0 + border + rpizLength / 2 - (lengthBetweenScrews / 2), height = screwHeight)
 | |
| m25Screw(x = border + rpizWidth / 2 - (widthBetweenScrews / 2), y = 0 + border + rpizLength / 2 + lengthBetweenScrews / 2, height = screwHeight)
 | |
| m25Screw(x = border + rpizWidth / 2 + widthBetweenScrews / 2, y = 0 + border + rpizLength / 2 + lengthBetweenScrews / 2, height = screwHeight)
 | |
| m25Screw(x = border + rpizWidth / 2 + widthBetweenScrews / 2, y = 0 + border + rpizLength / 2 - (lengthBetweenScrews / 2), height = screwHeight)
 | |
| 
 | |
| shell(case, faces = [END], thickness = caseThickness)
 |