mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
error check for nonexistent pitch, doc fixes
This commit is contained in:
parent
9b6abb6e31
commit
4a4f871ae8
1 changed files with 23 additions and 7 deletions
28
screws.scad
28
screws.scad
|
@ -24,21 +24,32 @@ include <screw_drive.scad>
|
||||||
// various head types and drive types that should match standard hardware.
|
// various head types and drive types that should match standard hardware.
|
||||||
// Subsection: Screw Naming
|
// Subsection: Screw Naming
|
||||||
// You can specify screws using a string that specifies the screw.
|
// You can specify screws using a string that specifies the screw.
|
||||||
// For ISO (metric) screws the specification has the form: "M`<size>`x`<pitch>`,`<length>`,
|
// Metric or ISO screws are specified by a diameter in millimeters and a thread pitch in millimeters. For example,
|
||||||
|
// an M8x2 screw has a nominal diameter of 8 mm and a thread pitch of 2 mm.
|
||||||
|
// The screw specification for these screws has the form: "M`<size>`x`<pitch>`,`<length>`,
|
||||||
// so "M6x1,10" specifies a 6mm diameter screw with a thread pitch of 1mm and length of 10mm.
|
// so "M6x1,10" specifies a 6mm diameter screw with a thread pitch of 1mm and length of 10mm.
|
||||||
// You can omit the pitch or length, e.g. "M6x1", or "M6,10", or just "M6".
|
// You can omit the pitch or length, e.g. "M6x1", or "M6,10", or just "M6". If you omit the
|
||||||
|
// length then you must provide the `length` parameter. If you omit the pitch, the library
|
||||||
|
// provides a standard pitch for the specified diameter.
|
||||||
// .
|
// .
|
||||||
// For UTS (English) screws the specification has the form `<size>`-`<threadcount>`,`<length>`, e.g.
|
// Imperial or UTS screws are specified by a diameter and the number of threads per inch.
|
||||||
|
// For large screws, the diameter is simply the nominal diameter in inches, so a 5/16-18 screw
|
||||||
|
// has a nominal diameter of 5/16 inches and 18 threads per inch. For diameters smaller than
|
||||||
|
// 1/4 inch, the screw diameter is given using a screw gauge, which can be from 0 up to 12.
|
||||||
|
// A common smaller size is #8-32, an 8 gauge screw with 32 threads per inch.
|
||||||
|
// For UTS screws the specification has the form `<size>`-`<threadcount>`,`<length>`, e.g.
|
||||||
// "#8-32,1/2", or "1/4-20,1". The units are in inches, including the length. Size can be a
|
// "#8-32,1/2", or "1/4-20,1". The units are in inches, including the length. Size can be a
|
||||||
// number from 0 to 12 with or without a leading # to specify a screw gauge size, or any other
|
// gauge number from 0 to 12 with or without a leading # to specify a screw gauge size, or any other
|
||||||
// value to specify a diameter in inches, either as a float or a fraction, so "0.5-13" and
|
// value to specify a diameter in inches, either as a float or a fraction, so "0.5-13" and
|
||||||
// "1/2-13" are equivalent. To force interpretation of the value as inches add '' (two
|
// "1/2-13" are equivalent. To force interpretation of the value as inches add '' (two
|
||||||
// single-quotes) to the end, e.g. "1''-4" is a one inch screw and "1-80" is a very small
|
// single-quotes) to the end, e.g. "1''-4" is a one inch screw and "1-80" is a very small
|
||||||
// 1-gauge screw. The pitch is specified using a thread count, the number of threads per inch.
|
// 1-gauge screw. The pitch is specified using a thread count, the number of threads per inch.
|
||||||
// As with the ISO screws, you can omit the pitch or length and specify "#6-32", "#6,3/4", or simply #6.
|
// As with the ISO screws, you can omit the pitch or length and specify "#6-32", "#6,3/4", or simply #6.
|
||||||
|
// As in the metric case, if you omit the length then you must provide the `length` parameter. If you omit the pitch, the
|
||||||
|
// library provides a standard pitch for the specified diameter.
|
||||||
// Subsection: Standard Screw Pitch
|
// Subsection: Standard Screw Pitch
|
||||||
// If you omit the pitch when specifying a screw or nut then the library supplies a standard screw pitch based
|
// If you omit the pitch when specifying a screw or nut then the library supplies a standard screw pitch based
|
||||||
// on the screw diameter. For each screw diameter, multiple standard pitches are possible.
|
// on the screw diameter as listed in ISO 724 or ASME B1.1. For many diameters, multiple standard pitches exist.
|
||||||
// The available thread pitch types are different for ISO and UTS:
|
// The available thread pitch types are different for ISO and UTS:
|
||||||
// .
|
// .
|
||||||
// | ISO | UTS |
|
// | ISO | UTS |
|
||||||
|
@ -566,7 +577,9 @@ module screw(spec, head, drive, thread, drive_size,
|
||||||
dummy = _validate_screw_spec(spec);
|
dummy = _validate_screw_spec(spec);
|
||||||
$screw_spec = spec;
|
$screw_spec = spec;
|
||||||
pitch = struct_val(spec, "pitch") ;
|
pitch = struct_val(spec, "pitch") ;
|
||||||
|
fdsa= echo(pitch=pitch);
|
||||||
threadspec = pitch==0 ? undef : thread_specification(spec, internal=_internal, tolerance=tolerance);
|
threadspec = pitch==0 ? undef : thread_specification(spec, internal=_internal, tolerance=tolerance);
|
||||||
|
f=echo(threadspec);
|
||||||
nominal_diam = _nominal_diam(spec);
|
nominal_diam = _nominal_diam(spec);
|
||||||
d_major = pitch==0 ? nominal_diam : mean(struct_val(threadspec, "d_major"));
|
d_major = pitch==0 ? nominal_diam : mean(struct_val(threadspec, "d_major"));
|
||||||
length = struct_val(spec,"length");
|
length = struct_val(spec,"length");
|
||||||
|
@ -2178,6 +2191,7 @@ function _screw_info_english(diam, threadcount, head, thread, drive) =
|
||||||
tentry = struct_val(UTS_thread, diam)
|
tentry = struct_val(UTS_thread, diam)
|
||||||
)
|
)
|
||||||
assert(is_def(tentry), str("Unknown screw size, \"",diam,"\""))
|
assert(is_def(tentry), str("Unknown screw size, \"",diam,"\""))
|
||||||
|
assert(is_def(tentry[tind]), str("No ",thread," pitch known for screw size, \"",diam,"\""))
|
||||||
INCH / tentry[tind],
|
INCH / tentry[tind],
|
||||||
head_data =
|
head_data =
|
||||||
head=="none" ? let (
|
head=="none" ? let (
|
||||||
|
@ -2607,8 +2621,10 @@ function _screw_info_metric(diam, pitch, head, thread, drive) =
|
||||||
],
|
],
|
||||||
tentry = struct_val(ISO_thread, diam)
|
tentry = struct_val(ISO_thread, diam)
|
||||||
)
|
)
|
||||||
assert(is_def(tentry), str("Unknown screw size, M",diam,""))
|
assert(is_def(tentry), str("Unknown screw size, M",diam))
|
||||||
|
assert(is_def(tentry[tind]), str("No ",thread," pitch known for M",diam))
|
||||||
tentry[tind],
|
tentry[tind],
|
||||||
|
|
||||||
head_data =
|
head_data =
|
||||||
head=="none" ? let(
|
head=="none" ? let(
|
||||||
metric_setscrew =
|
metric_setscrew =
|
||||||
|
|
Loading…
Reference in a new issue