/
morbo
executable file
·64 lines (47 loc) · 1.71 KB
/
morbo
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#!/usr/bin/env perl
use strict;
use warnings;
use FindBin;
use lib "$FindBin::Bin/../lib";
use Getopt::Long qw(GetOptions :config no_auto_abbrev no_ignore_case);
GetOptions(
'h|help' => \my $help,
'l|listen=s' => \my @listen,
'v|verbose' => sub { $ENV{MORBO_VERBOSE} = 1 },
'w|watch=s' => \my @watch
);
# Usage
die <<"EOF" if $help || !(my $app = shift);
usage: $0 [OPTIONS] [APPLICATION]
morbo script/myapp
morbo myapp.pl
morbo -w /usr/local/lib -w public myapp.pl
These options are available:
-h, --help Show this message.
-l, --listen <location> Set one or more locations you want to listen
on, defaults to the value of MOJO_LISTEN or
"http://*:3000".
-v, --verbose Print details about what files changed to
STDOUT.
-w, --watch <directory/file> Set one or more directories and files to
watch for changes, defaults to the
application script as well as the "lib" and
"templates" directories in the current
working directory.
EOF
$ENV{MOJO_LISTEN} = join(',', @listen) if @listen;
require Mojo::Server::Morbo;
my $morbo = Mojo::Server::Morbo->new;
$morbo->watch(\@watch) if @watch;
$morbo->run($app);
=head1 NAME
morbo - Morbo HTTP and WebSocket development server
=head1 SYNOPSIS
$ morbo --help
$ morbo myapp.pl
=head1 DESCRIPTION
Start L<Mojolicious> and L<Mojolicious::Lite> applications with the
L<Mojo::Server::Morbo> web server.
=head1 SEE ALSO
L<Mojolicious>, L<Mojolicious::Guides>, L<http://mojolicio.us>.
=cut