~loggerhead-team/loggerhead/trunk-rich

« back to all changes in this revision

Viewing changes to serve-branches

  • Committer: Martin Albisetti
  • Date: 2008-07-26 17:53:10 UTC
  • mfrom: (185 jam_fixes)
  • mto: This revision was merged to the branch mainline in revision 187.
  • Revision ID: argentina@gmail.com-20080726175310-fa95p4n9egnpy0hr
MergeĀ fromĀ trunk

Show diffs side-by-side

added added

removed removed

Lines of Context:
16
16
"""Search for branches underneath a directory and serve them all."""
17
17
 
18
18
import logging
19
 
import os
20
19
import sys
21
20
 
22
 
from optparse import OptionParser
23
 
 
24
21
from paste import httpserver
25
22
from paste.httpexceptions import HTTPExceptionHandler
26
23
from paste.translogger import TransLogger
27
24
 
28
 
from loggerhead import __version__
29
 
from loggerhead.apps.filesystem import (
30
 
    BranchesFromFileSystemRoot, UserBranchesFromFileSystemRoot)
31
 
 
32
 
 
33
 
def command_line_parser():
34
 
    parser = OptionParser("%prog [options] <path>")
35
 
    parser.set_defaults(
36
 
        user_dirs=False,
37
 
        show_version=False,
38
 
        )
39
 
    parser.add_option("--user-dirs", action="store_true", dest="user_dirs",
40
 
                      help="Serve user directories as ~user.")
41
 
    parser.add_option("--trunk-dir", metavar="DIR",
42
 
                      help="The directory that contains the trunk branches.")
43
 
    parser.add_option("--version", action="store_true", dest="show_version",
44
 
                      help="Print the software version and exit")
45
 
    return parser
46
 
 
47
 
 
48
 
def main(args):
49
 
    logging.basicConfig()
50
 
    logging.getLogger().setLevel(logging.DEBUG)
51
 
 
52
 
    parser = command_line_parser()
53
 
    (options, args) = parser.parse_args(sys.argv[1:])
54
 
 
55
 
    if options.show_version:
56
 
        print "loggerhead %s" % __version__
57
 
        sys.exit(0)
58
 
 
59
 
    if len(args) > 1:
60
 
        parser.print_help()
61
 
        sys.exit(1)
62
 
    elif len(args) == 1:
63
 
        [path] = args
64
 
    else:
65
 
        path = '.'
66
 
 
67
 
    if not os.path.isdir(path):
68
 
        print "%s is not a directory" % path
69
 
        sys.exit(1)
70
 
 
71
 
    if options.trunk_dir and not options.user_dirs:
72
 
        print "--trunk-dir is only valid with --user-dirs"
73
 
        sys.exit(1)
74
 
 
75
 
    if options.user_dirs:
76
 
        if not options.trunk_dir:
77
 
            print "You didn't specify a directory for the trunk directories."
78
 
            sys.exit(1)
79
 
        app = UserBranchesFromFileSystemRoot(path, options.trunk_dir)
80
 
    else:
81
 
        app = BranchesFromFileSystemRoot(path)
82
 
    app = HTTPExceptionHandler(app)
83
 
    app = TransLogger(app)
84
 
 
85
 
    try:
86
 
        from paste.deploy.config import PrefixMiddleware
87
 
    except ImportError:
88
 
        pass
89
 
    else:
90
 
        app = PrefixMiddleware(app)
91
 
 
92
 
    httpserver.serve(app, host='0.0.0.0', port='8080')
93
 
 
94
 
 
95
 
if __name__ == "__main__":
96
 
    main(sys.argv)
 
25
from loggerhead.apps.filesystem import BranchesFromFileSystemRoot
 
26
 
 
27
 
 
28
logging.basicConfig()
 
29
logging.getLogger().setLevel(logging.DEBUG)
 
30
 
 
31
if len(sys.argv) > 1:
 
32
    path = sys.argv[1]
 
33
else:
 
34
    path = '.'
 
35
 
 
36
app = BranchesFromFileSystemRoot(path)
 
37
 
 
38
app = HTTPExceptionHandler(app)
 
39
app = TransLogger(app)
 
40
 
 
41
try:
 
42
    from paste.deploy.config import PrefixMiddleware
 
43
except ImportError:
 
44
    pass
 
45
else:
 
46
    app = PrefixMiddleware(app)
 
47
 
 
48
#from paste.evalexception import EvalException
 
49
#app = EvalException(app)
 
50
 
 
51
httpserver.serve(app, host='0.0.0.0', port='8080')