Beefy Boxes and Bandwidth Generously Provided by pair Networks
The stupid question is the question not asked

comment on

( #3333=superdoc: print w/replies, xml ) Need Help??


The Data::Flow module allows you to specify a hash of "recipes" that fetch or manipulate data. Each recipe has a name (the hash key), which you can use to set the input or fetch the output value of the recipe using the Data::Flow set and get methods. A recipe can depend on other prerequisite recipes, which means that the input of one recipe can be taken from the output of other recipes. You can use this to create a hierarchy (or other structure) of dependent recipes. The cool thing is that you then call for a specific type of output, and the data flows from its input recipes through all of the dependent recipes to your output, without you having to code the calling structure directly. This allows for a lot of flexibility, because you can manipulate your calling structure by changing your hash recipes and dependencies, not by having to find all of the places that subroutine X is called in your code.

Why should you use it?

The Data::Flow module would be especially appropriate if your data can be processed in a lot of complicated and inter-related ways, and you want a lot of flexibility in how you'll want it processed, now or in the future.

Why should you NOT use it?

For straightforward processing of your data, the recipe structure of Data::Flow can be overkill. It's not as intuitively obvious as just hacking the code.

Related Modules

The C::Scan module uses the Data::Flow module. (Both were written by Ilya.)


The Data::Flow documentation provides an okay example, but looking at the C::Scan module will teach you more about using Data::Flow powerfully.

In reply to Data::Flow by knight

Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post; it's "PerlMonks-approved HTML":

  • Are you posting in the right place? Check out Where do I post X? to know for sure.
  • Posts may use any of the Perl Monks Approved HTML tags. Currently these include the following:
    <code> <a> <b> <big> <blockquote> <br /> <dd> <dl> <dt> <em> <font> <h1> <h2> <h3> <h4> <h5> <h6> <hr /> <i> <li> <nbsp> <ol> <p> <small> <strike> <strong> <sub> <sup> <table> <td> <th> <tr> <tt> <u> <ul>
  • Snippets of code should be wrapped in <code> tags not <pre> tags. In fact, <pre> tags should generally be avoided. If they must be used, extreme care should be taken to ensure that their contents do not have long lines (<70 chars), in order to prevent horizontal scrolling (and possible janitor intervention).
  • Want more info? How to link or How to display code and escape characters are good places to start.
Log In?

What's my password?
Create A New User
Domain Nodelet?
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others browsing the Monastery: (2)
As of 2023-09-29 20:17 GMT
Find Nodes?
    Voting Booth?

    No recent polls found