Suppose we want to interfere with how a vaguely Unix-style C compiler does its job, and that we want to try compiling existing software with this modified compiler. Assuming the build system will let us do something like:
... then we'd like something that is a drop-in replacement at the command-line level. Let's also assume that our modifications are black-box: we want to do “what the stock compiler was doing”, modulo some tweaks at the edges. The tweaks might be running extra tools, munging the compiler command-line options, doing source-to-source rewrites on some input files, postprocessing output files, and so on. Although I say “tweaks”, the extent of our interference could be arbitrary, once we get into rewriting the input or output programs. But we are still making at least some use of the original compiler.
This requirement is common if you do research with compilers. The time-honoured way is to write a Python script or Perl script or shell script that parses a command line, delegates to the real compiler while also doing the desired extra stuff. Then you build the existing software using this wrapper script, e.g. by setting CC to point this wrapper script.