PS
# Chuck.m4
gen_init s_init(Views) sinclude(tst.dim)
#
#################################################################
divert(-1)

                            `r_box(angle,pos,string)
                             Rotated text on a white background
                             (requires pstricks)'
define(`r_box',
`ifpstricks(`M4tmp: ifelse(`$2',,Here,`$2')
 command sprintf("\rput{%g}(%g,%g){",`$1',crl(M4tmp.x),crl(M4tmp.y))
 f_box(`$3') at Orig
command "}%"')')
define(`crl',`int(`($1)'/scale*1000000)/1000000')

                            `r_dimen(linespec,offset,label,tic offset,<->,pos)
                             dimension_ with rotated text on white background'
define(`r_dimen',
`M4tmp: dimension_(`$1',`$2',,,`$4',`$5')
 r_box(rp_ang*rtod_,ifelse(`$6',,M4tmp+vec_(0,`$2'),`$6'),`$3')')

                            `ctrline(linespec,len)
                             Centerline'
define(`cdashl',0.1*scale)
define(`cgapl',0.03*scale)
define(`ctrline',`rpoint_(ifelse(`$1',,`to rvec_(linewid,0)',`$1'))
 define(`m4h',ifelse(`$2',,1*scale,`$2'))dnl
 m4n = int(rp_len/2/(m4h))*2+1
 for i=1 to m4n do {
   line to rvec_(rp_len/m4n/2-cdashl/2-cgapl,0)
   move to rvec_(cgapl,0); line to rvec_(cdashl,0); move to rvec_(cgapl,0)
   line thick dimensionth to rvec_(rp_len/m4n/2-cdashl/2-cgapl,0) } ')

                            `ctrarcr(pos,radius,startang,endang,len)
                             Arc cr centerline'
define(`ctrarcr',`dnl
 define(`m5h',ifelse(`$5',,1*scale,`$5'))dnl
 rp_len = abs((`$2')*(`$4'-(`$3')))
 m5n = int(rp_len/2/(m5h))*2+1
 m5a = (rp_len/m5n/2-cdashl/2-cgapl)/(`$2')
 m5s = cdashl/(`$2')
 m5sa = `$3'
 for m4irr=1 to m5n do {
   arc from `$1'+(rect_(`$2',m5sa)) to `$1'+(rect_(`$2',m5sa+m5a)) \
     with .c at `$1'
   m5sa = m5sa+m5a+cgapl/(`$2')
   arc from `$1'+(rect_(`$2',m5sa)) to `$1'+(rect_(`$2',m5sa+m5s)) \
     with .c at `$1'
   m5sa = m5sa+m5s+cgapl/(`$2')
   arc from `$1'+(rect_(`$2',m5sa)) to `$1'+(rect_(`$2',m5sa+m5a)) \
     with .c at `$1'
   m5sa = m5sa+m5a
   } ')

divert(0)dnl
#################################################################

scale = 25.4*2
tic = 3.6bp__

command "{\sf"

define(`visible_thick',`linethick_(visibleth)')
define(`hidden_thick',`linethick_(hiddenth)')
define(`dimension_thick',`linethick_(dimensionth)
 arrowwid = 1.5*arrowwid; arrowht = 1.5*arrowht; ')

d1 = 230
d2 = 204
d3 = 140

 visibleth = 1.2
 dimensionth = 0.4
 hiddenth = dimensionth

Orig: Here
visible_thick
 D3: circle diam d3 at Orig
 D2: circle diam d2 at Orig

 rr = d1/2
 r = 40
 h = 110/2
 thet = asin((h+r)/(rr+r))
 X1: rect_(rr,thet)
 P1: rect_(rr+r,thet)

dimension_thick
 cross(at (P1.x,-P1.y))
 cross(at (-P1.x,P1.y))

# Top outer visible line
visible_thick
# top arcs
 arc ccw from (-P1.x,h) to (-X1.x,X1.y) with .c at (-P1.x,P1.y)
 arc cw to X1 with .c at Orig
 arc ccw from X1 to (P1.x,h) with .c at P1
# right end
 line from (P1.x,h) to (305/2,h) then to (305/2,32/2) then left 40-3
 arc ccw rad 3
 line down 32-2*3
 arc ccw rad 3
dimension_thick {
 r_dimen(up 32 with .c at (305/2-5,0),0,32)
 arrow <- up 8 right 8 then right 4 from last arc.sw
 "3$\,$R" ljust
 r_dimen(up h*2 at (305/2,0),-10,110)
}; visible_thick
 line right 40-3 then to (305/2,-h) then to (P1.x,-h)
# bottom arcs
 arc ccw to (X1.x,-X1.y) with .c at P1.x,-P1.y
 arc cw to (-X1.x,-X1.y) with .c at Orig
 arc ccw to (-P1.x,-h) with .c at (-P1.x,-P1.y)
# left end
 line from (-P1.x,-h) to (-305/2,-h) then to (-305/2,-25/2) then right 25
 down; arc ccw rad 3
 line right 40-25-2*3
 arc ccw rad 3
 line up 25
 {R: line invis down 10 at (2nd last line,last line) }
 arc ccw rad 3
 line left 40-25-2*3
 arc ccw rad 3
 line to (-305/2,25/2) then to (-305/2,h) then to (-P1.x,h)

dimension_thick
# centre
 ctrline(right 305-30 with .c at Orig,60)
 ctrline(up d1+10 with .c at Orig,)

 {BX: box invis ht 25+2*3 wid 40-25 rad 3 with .w at (-305/2+25,0)}
 Q: line invis from BX.n to BX.s; R: line invis from BX.se up 10 left 10
 X: Intersect_(Q,R)
 line <-> from BX.se to X then to (X.x,-X.y) then to BX.nw
 r_box(90,BX,```3$\,$R''')

# Drill centres
 D[1]: 35,sqrt(85^2-35^2)
 D[2]: -D[1].x,D[1].y
 D[3]: -D[1].x,-D[1].y
 D[4]: D[1].x,-D[1].y
 ctrline(from D[3] to D[1] chop 15)
 ctrline(to rvec_(2*15,0))
 ctrline(from D[3]+vec_(-15,0) to D[3]+vec_(15,0))
 ctrline(from D[2] to D[4] chop 15)
 ctrline(to rvec_(2*15,0))
 ctrline(from D[2]+vec_(-15,0) to D[2]+vec_(15,0))
visible_thick
 for i=1 to 4 do {
   circle diam 16 at D[i]
   for j = 0 to 7 do { arcr(D[i],23/2,j/8*twopi_,(j+3/4)/8*twopi_) ccw }
   }

hidden_thick
 for s=-1 to 1 by 2 do {
   line dashed from (-305/2,s*h) to (305/2,s*h)
   line dashed from (-305/2,s*30.6) to (305/2,s*30.6)
   line dashed from (-305/2,s*21.1) to (305/2,s*21.1)
#   line dashed from (-305/2+25+2,s*21.1) to (305/2,s*21.1)
   line dashed  dashwid/2 from (-305/2+25,s*25/2) down -s*(40/2-25/2-2);
   if s<0 then { arc dashed dashwid/4 ccw rad 2 } \
   else { up; arc dashed dashwid/4 cw rad 2 }
   line dashed to ((305/2,0),Here)
   for k = -1 to 1 by 2 do {
     move to (k*305/2,s*(30.6+10))
     { dashline(from Here+(0,s*9.5/2) right -k*16,,dashwid/2)
       dashline(right -k*9.5/2/2 up -s*9.5/2,,dashwid/3)
       dashline(left -k*9.5/2/2 up -s*9.5/2,,dashwid/3)
       dashline(left -k*16,,dashwid/2)
       dashline(from Here+(-k*16,0) up s*9.5,,dashwid/2.5) }
     { dashline(from Here+(0,s*11/2) right -k*36.5,,dashwid/2)
       dashline(right -k*11/2/2 up -s*11/2,,dashwid/3)
       dashline(left -k*11/2/2 up -s*11/2,,dashwid/3)
       dashline(left -k*36.5,,dashwid/2)
       dashline(from Here+(-k*36.5,0) up s*11,,dashwid/2.5) }
     { dashline(from Here+(0,s*13/2) right -k*32,,dashwid/2)
       dashline(down s*13,,dashwid/2)
       dashline(left -k*32,,dashwid/2) }
     ctrline(right -k*20 chop -3 chop 0); ctrline(right -k*20 chop 0 chop -3)
     }
   }

dimension_thick
# bottom
 dimension_(from (-305/2,-h) to (305/2,-h),-(rr*1.1-h),"305",20pt__)
# outer radii
 r_dimen(from (-P1.x,P1.y) down 40*cosd(30) right 40*sind(30),0,40,,->)
 r_dimen(from (P1.x,-P1.y)+(Rect_(40,120)) \
  down 40*cosd(30) right 40*sind(30),0,40,,<-)
# main diameter
 r_dimen(from (Rect_(rr,180+50)) to (Rect_(rr,50)),,230,,,(Rect_(50,50)))
# inner circles
 r_dimen(from (Rect_(d2/2,180+25)) to (Rect_(d2/2,25)),,204,,,(Rect_(25,25)))
 r_dimen(from (Rect_(d3/2,180-12)) to (Rect_(d3/2,-12)),,140,,,(Rect_(25,-12)))

# bolt hole placement diameter
 r_dimen(from Orig to (Rect_(85,-43)),,``85$\,$R'',,->,(Rect_(20,-43)))
# left slot
 r_dimen(from (-305/2+6,-25/2) up 25,0,25)
 r_dimen(from (-305/2,-26) right 40,0,40)
 line from last line.end to (last line.end.x,BX.s.y) chop -tic chop 0
 r_dimen(from (-305/2,26) right 25,0,25)
 line from last line.end to (last line.end.x,BX.n.y) chop -tic chop 0
# right slot
 r_dimen(from (305/2-40,-32/2-10) right 40,0,40)
 line from (305/2-40,-32/2) down 10+tic
# drill-holes
 for i=1 to 4 do {
   ctrarcr(Orig,85,atan2(D[i].y,D[i].x)-10*dtor_,atan2(D[i].y,D[i].x)+10*dtor_)
   }
 ctrarcr(Orig,85,atan2(D[4].y,D[4].x)+10*dtor_,atan2(D[4].y,D[4].x)+25*dtor_)
 ctrline(up 30 at D[3])
 ctrline(up 30 at D[4])
 r_dimen(from D[3]+(0,-14) right 35,0,35)
 r_dimen(from (0,D[3].y-14) right 35,0,35)

command "}%"
PE