<div dir="auto">I often define<div dir="auto"><br></div><div dir="auto">tracer prefix x = trace (prefix ++ ": " ++ show x) x</div><div dir="auto"><br></div><div dir="auto">A bit arbitrary with the choice of ": ", but quite convenient. The with variant would be</div><div dir="auto"><br></div><div dir="auto">tracerWith prefix f x = trace (prefix ++ ": " ++ show (f x)) x</div><div class="gmail_extra" dir="auto"><br><div class="gmail_quote">On Feb 9, 2018 5:09 PM, "Kris Nuttycombe" <<a href="mailto:kris.nuttycombe@gmail.com">kris.nuttycombe@gmail.com</a>> wrote:<br type="attribution"><blockquote class="quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">When using Debug.Trace for debugging, a very common operation is to prefer to trace only some subset or function of an intermediate result. As a consequence, I propose adding the following function to Debug.Trace:<div><br></div><div><div>traceWith :: (Show b) => (a -> b) -> a -> a</div><div>traceWith f a = trace (show $ f a) a</div><div><br></div></div><div>While it's trivial to define, I have found this to be one of the most useful functions in my trace-based debugging toolkit, hence my proposal that it be added to base. It generalizes `traceShowId` in a meaningful and useful fashion. </div><div><br></div><div>As this is the first such proposal I've put forth, please let me know if I'm doing anything wrong with it!</div><div><br></div><div>Thanks,</div><div><br></div><div>Kris Nuttycombe</div></div>
<br>______________________________<wbr>_________________<br>
Libraries mailing list<br>
<a href="mailto:Libraries@haskell.org">Libraries@haskell.org</a><br>
<a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries" rel="noreferrer" target="_blank">http://mail.haskell.org/cgi-<wbr>bin/mailman/listinfo/libraries</a><br>
<br></blockquote></div><br></div></div>