PS
# ShiftR.m4
log_init

 iflatex(`textoffset = 1bp__; ifpsfrag(,`latexcommand({\sf)') ')

define(`lg_plen',3)

define(`customFF',`FlipFlopX(wid 10*L_unit ht FF_ht*L_unit,,
   :S;NE:CK;:R, N:PR, :Q;;ifelse(`$1',1,:lg_bartxt(Q)), N:CLR) ')

 F0: customFF(1)

 BUFFER_gate(,N) with .Out at F0.W1.end
   line left 2*L_unit from last [].In1
 T: dot
   reversed(`NOT_gate',left 10*L_unit)
 Serial: "\scriptsize\shortstack[r]{SERIAL\\ INPUT}" rjust
   line from T to (T,F0.W3) then to F0.W3.end

 NCLR: NOT_gate(right T.x-Serial.x from (Serial,F0.S1.end),N)
   "$\overline{\hbox{\scriptsize CLEAR}}$" at NCLR.start rjust

 CLK: NOT_gate(right T.x-Serial.x from NCLR.start+(0,-BUF_ht*3/2*L_unit))
   "\scriptsize CLOCK" at CLK.start rjust

for_(1,4,1,`
 F`'m4x: customFF(eval(m4x!=4)) with .W3.end at F`'eval(m4x-1).E3.end
 ')

 "\scriptsize OUTPUT" at F4.E1.end ljust
 line from NCLR.end to F4.S1.end

 down_
for_(0,4,1,`
 line from F`'m4x.W2.end down F0.W2.y-CLK.y
 ifelse(eval(m4x!=4),1,`dot',`line to CLK.end')
 N`'m4x: NAND_gate with .Out at F`'m4x.N1.end
   line up 2*L_unit from N`'m4x.In2
   { line up 6*L_unit from N`'m4x.In1
     "\scriptsize PR`'eval(4-m4x)" rjust }
   ifelse(eval(m4x!=4),1,
    `dot; dot(at F`'m4x.S1.end)',
    `line to (Serial,Here)
     "\scriptsize\shortstack[r]{PRESET\\ ENABLE}" wid 0.4 rjust ')
 ')

 iflatex(ifpsfrag(,`latexcommand(})'))
PE