I’ve been spending a fair bit of time working on Perl 5 core documentation. I started by editing and reorganizing some of the documents related to core hacking. This update will be in 5.14, due to be released in April. I’m also working on replacing the existing OO tutorials and updating the OO reference docs, though this won’t make it into the 5.14 release.
There’s been a lot of discussion on my OO doc changes, some of it useful, some of it useless, and some of it very rude (welcome to p5p!). Many of the people in the discussion don’t have a clear vision of who the docs are for. Without that vision, it’s really not possible to say whether a particular piece of documentation is good or not. A piece of documentation has to be good for a particular audience.
There’s a number of audiences for the Perl 5 core docs, and they fall along several axes. Here are the axes I’ve identified.
Newbies vs experienced users
Newbie-ness is about being new to a particular concept. You could be an experienced Perl user and still be new to OO programming in general, or new to OO in Perl.
For my OO docs, I’m writing for two audiences. First, I’m writing for people who are learning OO. That’s why the document starts with a general introduction to OO concepts. Second, I’m writing for people who want to learn more about how to do OO in Perl 5. For those people, the tutorial points them at several good OO systems on CPAN.
I’m not writing for people who already know Perl 5 OO and want to learn more, that’s what the perlobj document is for.
From the discussion on p5p, I can see that many people there have trouble understanding how newbies think. I like how chromatic addresses these issues in a couple of his blog posts.
How the reader uses Perl
Perl is used for lots of different tasks, including sysadmin scripts, glue code in a mostly non-Perl environment, full app development, etc.
Ideally, we’d have tutorial documents that are appropriate for each of these areas. I think the OO tutorial is most likely to be of interest to people writing full Perl applications. If you’re just whipping up some glue code, OO is probably overkill.
It would also be great to see some job-focused tutorials, like “Basic Perl Concepts for Sysadmins” or “Intro to Web Dev in Perl 5”. Yes, I know there are books on these topics, but having at least some pointers to modules/books/websites in the core docs is useful.
Constraints on the reader’s coding
If you’re doing green field development, you have the luxury of using the latest and greatest stuff on CPAN. If you’re maintaining a 10-year old Perl web app (I’m so sorry), then you probably don’t. Some readers may not be able to install CPAN modules. Some readers are stuck with in house web frameworks.
People stuck with old code need good reference docs that explain all the weird shit they come across. People writing new code should be guided to modern best practices. They don’t need to know that you can implement Perl 5 OO by hand using array references, ties, and lvalue methods
My OO tutorial is obviously aimed toward the green field developers. It’s all about pointing them at good options on CPAN. As I revise perlobj, I’m trying to make sure that I cover every nook and cranny so that the poor developer stuck with 2001 Perl OO code can understand what they’re maintaining.
(Sadly, that’s probably my code they’re stuck with.)
Conclusion
I’d like to see more explicit discussion of who the intended readers are when we discuss core documentation. Any major doc revision should start with a vision of who the docs are for.
There’s probably other axes we can think about when writing documentation as well. Comments on this are most welcome.
Comments
brian d foy, on 2011-03-16 16:07, said:
This is essentially why Perl marketing sucks. People tend to think that “marketing” means the Perl
community beating the Perl community’s message into the heads of everyone else in the world, instead
of carefully thinking about who’s using Perl and what those people and groups need to get to do
their work effectively.
One of the things I constantly have to say in Perl classes is that “You may not need this or ever use it, but you’ll probably run across some code that does”. That’s one of the reasons something like Learning Perl must partially-ignore “Best Practices”. We have to teach people to deal with bad code as well as write good code. If we only showed the latest fad, we’d alienate most of our audience since they have to work with stuff that already exists and they have little power to change drastically.
Mark A. Stratman, on 2011-03-16 16:18, said:
I’ve been on about this topic for a while now (e.g.
http://www.nntp.perl.org/group/perl.perl5.porters/2011/03/msg169804.html )
And been starting to write (and outline a talk), urging for us all to make greater efforts to acknowledge the difference between *reference* documents, and *tutorial* documents, and the goals of the readers of each.
I’m glad to see you pushing on this branch of the discussion as well (albeit in a more articulate, and louder voice ;)
“I’d like to see more explicit discussion of who the intended readers are when we discuss core
documentation.” …
I’ve always taken for granted that the very nature of Perl is “all things to all people”, and the
result has been its monstrous and unwieldy pile of perldocs.
In my opinion this naturally leads to multiple tracks of documentation:
- Reference / API
- Tutorials
- FAQ’s / How do I… ?
and so on.
Within each track you find a different set of underlying assumptions about the reader, his/her purpose for reading, and preexisting knowledge.
Your post here seems a good first step toward getting the commuity to decide exactly what these assumptions are (then ideally, rewriting and reorganizing the docs accordingly).
That’s my 20-second projected approach to this question anyhow. I’m curious to see where you’re going with this though. :)
Robert, on 2011-03-19 20:44, said:
I think by default if someone is looking up how to do OO in Perl, that person is NOT a newbie.
Dave Rolsky, on 2011-03-19 23:10, said:
@Robert: I alluded to this a bit in my blog entry, but “newbieness” is all relative. Someone could
know OO but not know OO in Perl. Someone could know Perl but not know OO.
I think by definition anyone wanting to read a tutorial on OO in Perl is probably new to that topic. That’s the readership that something called a tutorial attracts.