1CGI::Application::StrucUtsuerredC:o:nTtorCoiGlbIsu::t::eASdptpaPlreitrcelart(Di3oo)cnu:m:eSnttrautcitounred::Tools::Starter(3)
2
3
4
6 CGI::Application::Structured::Tools::Starter - template based module
7 starter for CGI::Application::Structured apps.
8
10 use Module::Starter qw(
11 Module::Starter::Simple
12 Module::Starter::Plugin::Template
13 CGI::Application::Structured::Tools::Starter
14 );
15
16 Module::Starter->create_distro(%args);
17
19 The prefered method for using this module is via the "cas-starter.pl"
20 in scripts script.
21
23 Version 0.015
24
26 This is a plugin for Module::Starter that builds a skeleton
27 CGI::Application::Structured module with all the extra files needed to
28 package it for CPAN. It also generates
29 - an CGI::Application::Structured controller base class for your
30 modules
31 - a customized CGI::Application::Dispatch subclass
32 - a preconfigured development config file
33 - a server.pl that runs out of the box
34 - helper scripts to generate Controller modules subclasses
35 - a helper script to generate DBIx::Class schema and result classes.
36
37 This module is inspired Module::Starter::Plugin::CGIApp by Jaldhar H.
38 Vyas .
39
41 new ( %args )
42 This method calls the "new" supermethod from
43 Module::Starter::Plugin::Template and then initializes the template
44 store and renderer. (See "templates" and "renderer" below.)
45
46 create_distro ( %args )
47 This method works as advertised in Module::Starter.
48
49 create_t( @modules )
50 This method creates a bunch of *.t files. @modules is a list of all
51 modules in the distribution.
52
53 render( $template, \%options )
54 This method is subclassed from Module::Starter::Plugin::Template.
55
56 It is given an HTML::Template and options and returns the resulting
57 document.
58
59 Data in the "Module::Starter" object which represents a reference to an
60 array @foo is transformed into an array of hashes with one key called
61 $foo_item in order to make it usable in an HTML::Template "TMPL_LOOP".
62 For example:
63
64 $data = ['a'. 'b', 'c'];
65
66 would become:
67
68 $data = [
69 { data_item => 'a' },
70 { data_item => 'b' },
71 { data_item => 'c' },
72 ];
73
74 so that in the template you could say:
75
76 <tmpl_loop data>
77 <tmpl_var data_item>
78 </tmpl_loop>
79
80 renderer ()
81 This method is subclassed from Module::Starter::Plugin::Template but
82 doesn't do anything as the actual template is created by "render" in
83 this implementation.
84
85 templates ()
86 This method is subclassed from Module::Starter::Plugin::Template.
87
88 It reads in the template files and populates the object's templates
89 attribute. The module template directory is found by checking the
90 "MODULE_TEMPLATE_DIR" environment variable and then the config option
91 "template_dir".
92
93 create_MANIFEST_SKIP()
94 This method creates a "MANIFEST.SKIP" file in the distribution's
95 directory so that unneeded files can be skipped from inclusion in the
96 distribution.
97
98 create_perlcriticrc ()
99 This method creates a "perlcriticrc" in the distribution's test
100 directory so that the behavior of "perl-critic.t" can be modified.
101
102 create_server_pl ()
103 This method creates "server.pl" in the distribution's root directory.
104
105 create_debug_sh ()
106 This method creates "debug.sh" in the distribution's root directory.
107 Starts werver with environment set to display ::Plugin::DebugScreen on
108 error
109
110 create_config_pl ()
111 This method creates "config-test.pl" in the distribution's root/config
112 directory.
113
114 create_create_pl ()
115 This method creates "create_controller.pl" in the distribution's
116 app/script directory.
117
118 create_tmpl ()
119 This method takes all the template files ending in .tmpl (representing
120 HTML::Template's and installs them into a directory under the distro
121 tree. For instance if the distro was called "Foo-Bar", the templates
122 would be installed in "Foo-Bar/templates".
123
124 Note the files will just be copied over not rendered.
125
126 create_submodule ()
127 Implements a default "Home" subclass of the main module. This module
128 will be auto configured as the default module in the Dispatch subclass.
129
130 create_submodule ()
131 Implements a default controller baseclass (main module).
132
133 create_dbic_pl ()
134 This method creates "create_dbic_schema.pl" in the distribution's
135 root/script/ directory.
136
137 create_dispatch ()
138 Implements a CGI::Application::Dispatch subclass for this app in the
139 lib directory under the main modules directory.
140
142 Please report any bugs or feature requests to through the web interface
143 at <http://rt.cpan.org>. I will be notified, and then you'll
144 automatically be notified of progress on your bug as I make changes.
145
147 Gordon Van Amburg, <vanamburg at cpan.org>
148
150 This module borrows heavily, is verily grafted from,
151 <Module::Starter::Plugin::CGIApp> by Jaldhar H. Vyas, <jaldhar at
152 braincells.com>
153
155 This program is free software; you can redistribute it and/or modify it
156 under the same terms as Perl itself.
157
159 CGI::Application::Structured-starter, CGI::Application::Structured,
160 CGI::Application, Module::Starter::Plugin::CGIApplication
161
162
163
164perl v5.38.0 CGI2:0:2A3p-p0l7i-c2a0tion::Structured::Tools::Starter(3)