Hi Dan,
I tested a few variations and think that we are not viewing a corrupt file as I was thinking but a few formating problems.
What I did in succession.
If I create a new Tasklist with a custom Attribute and texts I get something equal to the introduction tasklist.

If I add folks to the 'Allocated To' when printed they are connected with a '+', linewraping only applies if there is a space in the name itself. If the whitespaces do not come in handy it looks like this.

If additional columns are added the comments column moves out of the sheets scope like this.

If a comment contains an expetionally Long string without whitespace (a link for example) the column width also exceeds the sheet

Now these cases are rather exceptions than the rule in a tasklist, but on a 30 page protocol they happen.
Since it is not possible to cover every possible input with a flawless print layout I would suggest to approach like so
- In the 'allocated to' layout:
 Replace the '+' inbetween allocated to members with a comma and a whitespace ',_'.
 The ',' saves some space an i.m.o. looks more "official". The ' ' gives additional linewrapping options.
 
- Force all columns to fit the assigened width no matter what.
 Like so the majority of tasks will be perfectly readable and a few ones may look akward.
 If a few Long comments can enlarge the column over its limits all entries look akward.
- If an entry exceeds the column width and normal linewraping does not work, I find it legitimate to the split and wrap the string where necessary to fit the page.
What I would find very helpfull also would be being able to
- arrange the column order
- modify min/max column width
Perhaps that way you could outsource a few formating issues to the user ;)
Hope the attachments work this time and the lineout of the issues helps.
cheers
Mikro