From 78ea56b5e322746dbe49c51e93b5fd86574a6df7 Mon Sep 17 00:00:00 2001
From: AutomatedTester
Date: Mon, 16 Jan 2012 12:06:31 +0000
Subject: [PATCH 1/9] initial commit of docs
---
.gitignore | 2 +
docs/api-objects.txt | 21 +
docs/browsermobproxy-module.html | 164 +++++
docs/browsermobproxy-pysrc.html | 116 ++++
docs/browsermobproxy.client-module.html | 129 ++++
docs/browsermobproxy.client-pysrc.html | 236 +++++++
docs/browsermobproxy.client.Client-class.html | 607 ++++++++++++++++++
docs/browsermobproxy.server-module.html | 129 ++++
docs/browsermobproxy.server-pysrc.html | 181 ++++++
docs/browsermobproxy.server.Server-class.html | 380 +++++++++++
docs/class-tree.html | 113 ++++
docs/crarr.png | Bin 0 -> 340 bytes
docs/epydoc.css | 322 ++++++++++
docs/epydoc.js | 293 +++++++++
docs/frames.html | 17 +
docs/help.html | 268 ++++++++
docs/identifier-index.html | 260 ++++++++
docs/index.html | 17 +
docs/module-tree.html | 110 ++++
docs/redirect.html | 38 ++
docs/toc-browsermobproxy-module.html | 32 +
docs/toc-browsermobproxy.client-module.html | 31 +
docs/toc-browsermobproxy.server-module.html | 31 +
docs/toc-everything.html | 35 +
docs/toc.html | 35 +
index.html | 25 +
stylesheets/style.css | 21 +
27 files changed, 3613 insertions(+)
create mode 100644 .gitignore
create mode 100644 docs/api-objects.txt
create mode 100644 docs/browsermobproxy-module.html
create mode 100644 docs/browsermobproxy-pysrc.html
create mode 100644 docs/browsermobproxy.client-module.html
create mode 100644 docs/browsermobproxy.client-pysrc.html
create mode 100644 docs/browsermobproxy.client.Client-class.html
create mode 100644 docs/browsermobproxy.server-module.html
create mode 100644 docs/browsermobproxy.server-pysrc.html
create mode 100644 docs/browsermobproxy.server.Server-class.html
create mode 100644 docs/class-tree.html
create mode 100644 docs/crarr.png
create mode 100644 docs/epydoc.css
create mode 100644 docs/epydoc.js
create mode 100644 docs/frames.html
create mode 100644 docs/help.html
create mode 100644 docs/identifier-index.html
create mode 100644 docs/index.html
create mode 100644 docs/module-tree.html
create mode 100644 docs/redirect.html
create mode 100644 docs/toc-browsermobproxy-module.html
create mode 100644 docs/toc-browsermobproxy.client-module.html
create mode 100644 docs/toc-browsermobproxy.server-module.html
create mode 100644 docs/toc-everything.html
create mode 100644 docs/toc.html
create mode 100644 index.html
create mode 100644 stylesheets/style.css
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..3819313
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,2 @@
+*.swp
+*.swo
diff --git a/docs/api-objects.txt b/docs/api-objects.txt
new file mode 100644
index 0000000..521c89d
--- /dev/null
+++ b/docs/api-objects.txt
@@ -0,0 +1,21 @@
+browsermobproxy browsermobproxy-module.html
+browsermobproxy.client browsermobproxy.client-module.html
+browsermobproxy.server browsermobproxy.server-module.html
+browsermobproxy.client.Client browsermobproxy.client.Client-class.html
+browsermobproxy.client.Client.new_har browsermobproxy.client.Client-class.html#new_har
+browsermobproxy.client.Client.whitelist browsermobproxy.client.Client-class.html#whitelist
+browsermobproxy.client.Client.close browsermobproxy.client.Client-class.html#close
+browsermobproxy.client.Client.selenium_proxy browsermobproxy.client.Client-class.html#selenium_proxy
+browsermobproxy.client.Client.__init__ browsermobproxy.client.Client-class.html#__init__
+browsermobproxy.client.Client.LIMITS browsermobproxy.client.Client-class.html#LIMITS
+browsermobproxy.client.Client.har browsermobproxy.client.Client-class.html#har
+browsermobproxy.client.Client.blacklist browsermobproxy.client.Client-class.html#blacklist
+browsermobproxy.client.Client.new_page browsermobproxy.client.Client-class.html#new_page
+browsermobproxy.client.Client.limits browsermobproxy.client.Client-class.html#limits
+browsermobproxy.server.Server browsermobproxy.server.Server-class.html
+browsermobproxy.server.Server.create_proxy browsermobproxy.server.Server-class.html#create_proxy
+browsermobproxy.server.Server.url browsermobproxy.server.Server-class.html#url
+browsermobproxy.server.Server._is_listening browsermobproxy.server.Server-class.html#_is_listening
+browsermobproxy.server.Server.stop browsermobproxy.server.Server-class.html#stop
+browsermobproxy.server.Server.start browsermobproxy.server.Server-class.html#start
+browsermobproxy.server.Server.__init__ browsermobproxy.server.Server-class.html#__init__
diff --git a/docs/browsermobproxy-module.html b/docs/browsermobproxy-module.html
new file mode 100644
index 0000000..696a83c
--- /dev/null
+++ b/docs/browsermobproxy-module.html
@@ -0,0 +1,164 @@
+
+
+
+
+ browsermobproxy
+
+
+
+
+
+
+
+
+
+
+
+ Package browsermobproxy
+
+
+
+
+
+
+
+
+Package browsermobproxy source code
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Server
+
+
+
+
+
+
+ Client
+
+
+
+
+
+
+
+
+
+
diff --git a/docs/browsermobproxy-pysrc.html b/docs/browsermobproxy-pysrc.html
new file mode 100644
index 0000000..4dbf9aa
--- /dev/null
+++ b/docs/browsermobproxy-pysrc.html
@@ -0,0 +1,116 @@
+
+
+
+
+ browsermobproxy
+
+
+
+
+
+
+
+
+
+
+
+ Package browsermobproxy
+
+
+
+
+
+
+
+
+
+1 __version__ = '0.0.1'
+2
+3 from server import Server
+4 from client import Client
+5
+6 __all__ = [ 'Server' , 'Client' , 'browsermobproxy' ]
+7
+
+
+
+
+
+
+
+
+
diff --git a/docs/browsermobproxy.client-module.html b/docs/browsermobproxy.client-module.html
new file mode 100644
index 0000000..217374f
--- /dev/null
+++ b/docs/browsermobproxy.client-module.html
@@ -0,0 +1,129 @@
+
+
+
+
+ browsermobproxy.client
+
+
+
+
+
+
+
+
+
+Module client source code
+
+
+
+
+
+
+
+
+
+
diff --git a/docs/browsermobproxy.client-pysrc.html b/docs/browsermobproxy.client-pysrc.html
new file mode 100644
index 0000000..3f4c21b
--- /dev/null
+++ b/docs/browsermobproxy.client-pysrc.html
@@ -0,0 +1,236 @@
+
+
+
+
+ browsermobproxy.client
+
+
+
+
+
+
+
+
+
+
+ 1 from httplib2 import Http
+ 2 from urllib import urlencode
+ 3 import json
+
6
+
8 """
+
9 Initialises a new Client object
+
10 :Args:
+
11 - url: This is where the BrowserMob Proxy lives
+
12 """
+
13 self . host = url
+
14 h = Http ( )
+
15 resp , content = h . request ( '%s/proxy' % self . host , 'POST' , urlencode ( '' ) )
+
16 jcontent = json . loads ( content )
+
17 self . port = jcontent [ 'port' ]
+
18 url_parts = self . host . split ( ":" )
+
19 self . proxy = url_parts [ 0 ] + ":" + url_parts [ 1 ] + ":" + str ( self . port )
+
20
+
22 """
+
23 This sets a new HAR to be recorded
+
24 :Args:
+
25 - ref: A reference for the HAR. Defaults to None
+
26 """
+
27 h = Http ( )
+
28 resp , content = h . request ( '%s/proxy/%s/har' % ( self . host , self . port ) ,
+
29 'PUT' , ref or '' )
+
30
+
31 - def new_page ( self , ref ) :
+
32 """
+
33 This sets a new page to be recorded
+
34 :Args:
+
35 - ref: A reference for the new page. Defaults to None
+
36 """
+
37 h = Http ( )
+
38 resp , content = h . request ( '%s/proxy/%s/har/pageRef' % ( self . host , self . port ) ,
+
39 'PUT' , ref or '' )
+
40 if content :
+
41 return json . loads ( content )
+
42
+
43 @ property
+
45 """
+
46 Gets the HAR that has been recorded
+
47 """
+
48 h = Http ( )
+
49 resp , content = h . request ( '%s/proxy/%s/har' % ( self . host , self . port ) ,
+
50 'GET' )
+
51 return json . loads ( content )
+
52
+
54 """
+
55 Returns a Selenium WebDriver Proxy class with details of the HTTP Proxy
+
56 """
+
57 from selenium import webdriver
+
58 return webdriver . Proxy ( { "httpProxy" : self . proxy } )
+
59
+
61 """
+
62 Sets a list of URL patterns to whitelist
+
63 :Args:
+
64 - regex: a comma separated list of regular expressions
+
65 - status_code: the HTTP status code to return for URLs that do not match the whitelist
+
66
+
67 """
+
68 h = Http ( )
+
69 resp , content = h . request ( '%s/proxy/%s/whitelist' % ( self . host , self . port ) ,
+
70 'PUT' , urlencode ( { 'regex' : regexp , 'status' : status_code
+
71 } ) )
+
72
+
73
+
75 """
+
76 Sets a list of URL patterns to blacklist
+
77 :Args:
+
78 - regex: a comma separated list of regular expressions
+
79 - status_code: the HTTP status code to return for URLs that do not match the blacklist
+
80
+
81 """
+
82
+
83 h = Http ( )
+
84 resp , content = h . request ( '%s/proxy/%s/blacklist' % ( self . host , self . port ) ,
+
85 'PUT' , urlencode ( { 'regex' : regexp , 'status' : status_code
+
86 } ) )
+
87
+
88 LIMITS = {
+
89 'upstream_kbps' : 'upstreamKbps' ,
+
90 'downstream_kbps' : 'downstreamKbps' ,
+
91 'latency' : 'latency'
+
92 }
+
93
+
94
+
96 """
+
97 Limit the bandwidth through the proxy.
+
98 :Args:
+
99 - options: A dictionary with all the details you want to set.
+
100 downstreamKbps - Sets the downstream kbps
+
101 upstreamKbps - Sets the upstream kbps
+
102 latency - Add the given latency to each HTTP request
+
103 """
+
104 params = { }
+
105
+
106 for ( k , v ) in options . items ( ) :
+
107 if not self . LIMITS . has_key ( k ) :
+
108 raise Exception ( 'invalid key: %s' % k )
+
109
+
110 params [ self . LIMITS [ k ] ] = int ( v )
+
111
+
112 if len ( params . items ( ) ) == 0 :
+
113 raise Exception ( "You need to specify one of the valid Keys" )
+
114
+
115 h = Http ( )
+
116 resp , content = h . request ( '%s/proxy/%s/limit' % ( self . host , self . port ) ,
+
117 'PUT' , urlencode ( params ) )
+
118
+
120 """
+
121 shuts down the proxy and closes the port
+
122 """
+
123 h = Http ( )
+
124 resp , content = h . request ( '%s/proxy/%s' % ( self . host , self . port ) ,
+
125 'DELETE' )
+
126
+
+
+
+
+
+
+
+
+
diff --git a/docs/browsermobproxy.client.Client-class.html b/docs/browsermobproxy.client.Client-class.html
new file mode 100644
index 0000000..fc43b8e
--- /dev/null
+++ b/docs/browsermobproxy.client.Client-class.html
@@ -0,0 +1,607 @@
+
+
+
+
+ browsermobproxy.client.Client
+
+
+
+
+
+
+
+
+
+Class Client source code
+
+object --+
+ |
+ Client
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ new_har (self ,
+ ref =None )
+ This sets a new HAR to be recorded :Args:
+
+ source code
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ har (self )
+ Gets the HAR that has been recorded
+
+ source code
+
+
+
+
+
+
+
+
+
+
+
+
+
+ selenium_proxy (self )
+ Returns a Selenium WebDriver Proxy class with details of the HTTP
+ Proxy
+
+ source code
+
+
+
+
+
+
+
+
+
+
+
+
+
+ whitelist (self ,
+ regexp ,
+ status_code )
+ Sets a list of URL patterns to whitelist :Args:
+
+ source code
+
+
+
+
+
+
+
+
+
+
+
+
+
+ blacklist (self ,
+ regexp ,
+ status_code )
+ Sets a list of URL patterns to blacklist :Args:
+
+ source code
+
+
+
+
+
+
+
+
+
+
+
+
+
+ limits (self ,
+ options )
+ Limit the bandwidth through the proxy.
+
+ source code
+
+
+
+
+
+
+
+
+
+
+
+
+
+ close (self )
+ shuts down the proxy and closes the port
+
+ source code
+
+
+
+
+
+
+
+
+
+ Inherited from object
:
+ __delattr__
,
+ __format__
,
+ __getattribute__
,
+ __hash__
,
+ __new__
,
+ __reduce__
,
+ __reduce_ex__
,
+ __repr__
,
+ __setattr__
,
+ __sizeof__
,
+ __str__
,
+ __subclasshook__
+
+
+
+
+
+
+
+
+
+
+
+
+ LIMITS = {'upstream_kbps': 'upstreamKbps', 'downstream_kbps': ...
+
+
+
+
+
+
+
+
+
+ Inherited from object
:
+ __class__
+
+
+
+
+
+
+
+
+
+
+
+
+
+ __init__ (self ,
+ url )
+ (Constructor)
+
+ source code
+
+
+
+ Initialises a new Client object :Args:
+
+
+ url: This is where the BrowserMob Proxy lives
+
+
+
+ Overrides:
+ object.__init__
+
+
+
+
+
+
+
+
+
+
+ This sets a new HAR to be recorded :Args:
+
+
+ ref: A reference for the HAR. Defaults to None
+
+
+
+
+
+
+
+
+
+
+
+
+ This sets a new page to be recorded :Args:
+
+
+ ref: A reference for the new page. Defaults to None
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the HAR that has been recorded
+
+ Decorators:
+
+
+
+
+
+
+
+
+
+
+ whitelist (self ,
+ regexp ,
+ status_code )
+
+ source code
+
+
+
+ Sets a list of URL patterns to whitelist :Args:
+
+
+ regex: a comma separated list of regular expressions
+
+
+ status_code: the HTTP status code to return for URLs that do not
+ match the whitelist
+
+
+
+
+
+
+
+
+
+
+
+
+ blacklist (self ,
+ regexp ,
+ status_code )
+
+ source code
+
+
+
+ Sets a list of URL patterns to blacklist :Args:
+
+
+ regex: a comma separated list of regular expressions
+
+
+ status_code: the HTTP status code to return for URLs that do not
+ match the blacklist
+
+
+
+
+
+
+
+
+
+
+
+
+ Limit the bandwidth through the proxy. :Args:
+
+
+ options: A dictionary with all the details you want to set.
+ downstreamKbps - Sets the downstream kbps upstreamKbps - Sets the
+ upstream kbps latency - Add the given latency to each HTTP request
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ LIMITS
+
+
+
+
+ Value:
+
+{'upstream_kbps': 'upstreamKbps', 'downstream_kbps': 'downstreamKbps',
+ 'latency': 'latency'}
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/docs/browsermobproxy.server-module.html b/docs/browsermobproxy.server-module.html
new file mode 100644
index 0000000..8540363
--- /dev/null
+++ b/docs/browsermobproxy.server-module.html
@@ -0,0 +1,129 @@
+
+
+
+
+ browsermobproxy.server
+
+
+
+
+
+
+
+
+
+Module server source code
+
+
+
+
+
+
+
+
+
+
diff --git a/docs/browsermobproxy.server-pysrc.html b/docs/browsermobproxy.server-pysrc.html
new file mode 100644
index 0000000..9c8b043
--- /dev/null
+++ b/docs/browsermobproxy.server-pysrc.html
@@ -0,0 +1,181 @@
+
+
+
+
+ browsermobproxy.server
+
+
+
+
+
+
+
+
+
+
+ 1 from subprocess import Popen , PIPE , STDOUT
+ 2 import socket
+ 3 import time
+ 4
+ 5 from client import Client
+
9
+
11 """
+
12 Initialises a Server object
+
13
+
14 :Args:
+
15 - path : Path to the browsermob proxy batch file
+
16 - options : Dictionary that can hold the port. More items will be added in the future.
+
17 This defaults to an empty dictionary
+
18 """
+
19 self . path = path
+
20 self . port = options [ 'port' ] if options . has_key ( 'port' ) else 8080
+
21 self . command = [ 'sh' , path , '--port=%s' % self . port ]
+
22
+
24 """
+
25 This will start the browsermob proxy and then wait until it can interact with it
+
26 """
+
27 self . process = Popen ( self . command , stdout = PIPE , stderr = STDOUT )
+
28 count = 0
+
29 while not self . _is_listening ( ) :
+
30 time . sleep ( 0.1 )
+
31 count += 1
+
32 if count == 30 :
+
33 raise Exception ( "Can't connect to Browsermob-Proxy" )
+
34
+
36 """
+
37 This will stop the process running the proxy
+
38 """
+
39 try :
+
40 if self . process :
+
41 self . process . kill ( )
+
42 self . process . wait ( )
+
43 except AttributeError :
+
44
+
45 pass
+
46
+
47 @ property
+
49 """
+
50 Gets the url that the proxy is running on. This is not the URL clients should connect to.
+
51 """
+
52 return "http://localhost:%d" % self . port
+
53
+
54 @ property
+
56 """
+
57 Gets a client class that allow to set all the proxy details that you may need to.
+
58 """
+
59 client = Client ( self . url )
+
60 return client
+
61
+
63 try :
+
64 socket_ = socket . socket ( socket . AF_INET , socket . SOCK_STREAM )
+
65 socket_ . settimeout ( 1 )
+
66 socket_ . connect ( ( "localhost" , self . port ) )
+
67 socket_ . close ( )
+
68 return True
+
69 except socket . error :
+
70 return False
+
71
+
+
+
+
+
+
+
+
+
diff --git a/docs/browsermobproxy.server.Server-class.html b/docs/browsermobproxy.server.Server-class.html
new file mode 100644
index 0000000..54b3889
--- /dev/null
+++ b/docs/browsermobproxy.server.Server-class.html
@@ -0,0 +1,380 @@
+
+
+
+
+ browsermobproxy.server.Server
+
+
+
+
+
+
+
+
+
+Class Server source code
+
+object --+
+ |
+ Server
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ start (self )
+ This will start the browsermob proxy and then wait until it can
+ interact with it
+
+ source code
+
+
+
+
+
+
+
+
+
+
+
+
+
+ stop (self )
+ This will stop the process running the proxy
+
+ source code
+
+
+
+
+
+
+
+
+
+
+
+
+
+ url (self )
+ Gets the url that the proxy is running on.
+
+ source code
+
+
+
+
+
+
+
+
+
+
+
+
+
+ create_proxy (self )
+ Gets a client class that allow to set all the proxy details that you
+ may need to.
+
+ source code
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Inherited from object
:
+ __delattr__
,
+ __format__
,
+ __getattribute__
,
+ __hash__
,
+ __new__
,
+ __reduce__
,
+ __reduce_ex__
,
+ __repr__
,
+ __setattr__
,
+ __sizeof__
,
+ __str__
,
+ __subclasshook__
+
+
+
+
+
+
+
+
+
+
+ Inherited from object
:
+ __class__
+
+
+
+
+
+
+
+
+
+
+
+
+
+ __init__ (self ,
+ path ,
+ options ={} )
+ (Constructor)
+
+ source code
+
+
+
+ Initialises a Server object
+ :Args:
+
+
+ path : Path to the browsermob proxy batch file
+
+
+ options : Dictionary that can hold the port. More items will be added
+ in the future. This defaults to an empty dictionary
+
+
+
+ Overrides:
+ object.__init__
+
+
+
+
+
+
+
+
+
+
+ Gets the url that the proxy is running on. This is not the URL clients
+ should connect to.
+
+ Decorators:
+
+
+
+
+
+
+
+
+
+
+ Gets a client class that allow to set all the proxy details that you
+ may need to.
+
+ Decorators:
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/docs/class-tree.html b/docs/class-tree.html
new file mode 100644
index 0000000..57ef2e3
--- /dev/null
+++ b/docs/class-tree.html
@@ -0,0 +1,113 @@
+
+
+
+
+ Class Hierarchy
+
+
+
+
+
+
+
+
+
+ [ Module Hierarchy
+ | Class Hierarchy ]
+
+Class Hierarchy
+
+ object :
+ The most base type
+
+
+
+
+
+
+
+
+
+
diff --git a/docs/crarr.png b/docs/crarr.png
new file mode 100644
index 0000000000000000000000000000000000000000..26b43c52433b71e72a9a478c52d446278335f0e4
GIT binary patch
literal 340
zcmeAS@N?(olHy`uVBq!ia0vp^f?NMQuI$%1#8??M1uoZK
z0}62#ctjR6FvuMOVaB`*rFK9;mUKs7M+SzC{oH>NS%G}l0G|-o|NsA=J-p%i`2!7U
zCdJ_j4{u-SDsoA1U`TRixpVcz%O`iHHAYk?=&YaLkmD!Pp6~GW^M_S4D^grJKD>P~
zuPf!ku`N^TLavn`Edv_JSQ6wH%;50sMjDXg>*?YcQgJIe!GUqln>_|<+Os&OOUQS1
zY~Wzutud*iVS#|PHMc&?2WHoZpEo8l+6!Oc$x~=%U)469Gl^f?nq7UBw#1AXkrEde
cmFKWBXcRFE*(?@T0vgQV>FVdQ&MBb@0LpZ4r2qf`
literal 0
HcmV?d00001
diff --git a/docs/epydoc.css b/docs/epydoc.css
new file mode 100644
index 0000000..86d4170
--- /dev/null
+++ b/docs/epydoc.css
@@ -0,0 +1,322 @@
+
+
+/* Epydoc CSS Stylesheet
+ *
+ * This stylesheet can be used to customize the appearance of epydoc's
+ * HTML output.
+ *
+ */
+
+/* Default Colors & Styles
+ * - Set the default foreground & background color with 'body'; and
+ * link colors with 'a:link' and 'a:visited'.
+ * - Use bold for decision list terms.
+ * - The heading styles defined here are used for headings *within*
+ * docstring descriptions. All headings used by epydoc itself use
+ * either class='epydoc' or class='toc' (CSS styles for both
+ * defined below).
+ */
+body { background: #ffffff; color: #000000; }
+p { margin-top: 0.5em; margin-bottom: 0.5em; }
+a:link { color: #0000ff; }
+a:visited { color: #204080; }
+dt { font-weight: bold; }
+h1 { font-size: +140%; font-style: italic;
+ font-weight: bold; }
+h2 { font-size: +125%; font-style: italic;
+ font-weight: bold; }
+h3 { font-size: +110%; font-style: italic;
+ font-weight: normal; }
+code { font-size: 100%; }
+/* N.B.: class, not pseudoclass */
+a.link { font-family: monospace; }
+
+/* Page Header & Footer
+ * - The standard page header consists of a navigation bar (with
+ * pointers to standard pages such as 'home' and 'trees'); a
+ * breadcrumbs list, which can be used to navigate to containing
+ * classes or modules; options links, to show/hide private
+ * variables and to show/hide frames; and a page title (using
+ * ). The page title may be followed by a link to the
+ * corresponding source code (using 'span.codelink').
+ * - The footer consists of a navigation bar, a timestamp, and a
+ * pointer to epydoc's homepage.
+ */
+h1.epydoc { margin: 0; font-size: +140%; font-weight: bold; }
+h2.epydoc { font-size: +130%; font-weight: bold; }
+h3.epydoc { font-size: +115%; font-weight: bold;
+ margin-top: 0.2em; }
+td h3.epydoc { font-size: +115%; font-weight: bold;
+ margin-bottom: 0; }
+table.navbar { background: #a0c0ff; color: #000000;
+ border: 2px groove #c0d0d0; }
+table.navbar table { color: #000000; }
+th.navbar-select { background: #70b0ff;
+ color: #000000; }
+table.navbar a { text-decoration: none; }
+table.navbar a:link { color: #0000ff; }
+table.navbar a:visited { color: #204080; }
+span.breadcrumbs { font-size: 85%; font-weight: bold; }
+span.options { font-size: 70%; }
+span.codelink { font-size: 85%; }
+td.footer { font-size: 85%; }
+
+/* Table Headers
+ * - Each summary table and details section begins with a 'header'
+ * row. This row contains a section title (marked by
+ * 'span.table-header') as well as a show/hide private link
+ * (marked by 'span.options', defined above).
+ * - Summary tables that contain user-defined groups mark those
+ * groups using 'group header' rows.
+ */
+td.table-header { background: #70b0ff; color: #000000;
+ border: 1px solid #608090; }
+td.table-header table { color: #000000; }
+td.table-header table a:link { color: #0000ff; }
+td.table-header table a:visited { color: #204080; }
+span.table-header { font-size: 120%; font-weight: bold; }
+th.group-header { background: #c0e0f8; color: #000000;
+ text-align: left; font-style: italic;
+ font-size: 115%;
+ border: 1px solid #608090; }
+
+/* Summary Tables (functions, variables, etc)
+ * - Each object is described by a single row of the table with
+ * two cells. The left cell gives the object's type, and is
+ * marked with 'code.summary-type'. The right cell gives the
+ * object's name and a summary description.
+ * - CSS styles for the table's header and group headers are
+ * defined above, under 'Table Headers'
+ */
+table.summary { border-collapse: collapse;
+ background: #e8f0f8; color: #000000;
+ border: 1px solid #608090;
+ margin-bottom: 0.5em; }
+td.summary { border: 1px solid #608090; }
+code.summary-type { font-size: 85%; }
+table.summary a:link { color: #0000ff; }
+table.summary a:visited { color: #204080; }
+
+
+/* Details Tables (functions, variables, etc)
+ * - Each object is described in its own div.
+ * - A single-row summary table w/ table-header is used as
+ * a header for each details section (CSS style for table-header
+ * is defined above, under 'Table Headers').
+ */
+table.details { border-collapse: collapse;
+ background: #e8f0f8; color: #000000;
+ border: 1px solid #608090;
+ margin: .2em 0 0 0; }
+table.details table { color: #000000; }
+table.details a:link { color: #0000ff; }
+table.details a:visited { color: #204080; }
+
+/* Fields */
+dl.fields { margin-left: 2em; margin-top: 1em;
+ margin-bottom: 1em; }
+dl.fields dd ul { margin-left: 0em; padding-left: 0em; }
+dl.fields dd ul li ul { margin-left: 2em; padding-left: 0em; }
+div.fields { margin-left: 2em; }
+div.fields p { margin-bottom: 0.5em; }
+
+/* Index tables (identifier index, term index, etc)
+ * - link-index is used for indices containing lists of links
+ * (namely, the identifier index & term index).
+ * - index-where is used in link indices for the text indicating
+ * the container/source for each link.
+ * - metadata-index is used for indices containing metadata
+ * extracted from fields (namely, the bug index & todo index).
+ */
+table.link-index { border-collapse: collapse;
+ background: #e8f0f8; color: #000000;
+ border: 1px solid #608090; }
+td.link-index { border-width: 0px; }
+table.link-index a:link { color: #0000ff; }
+table.link-index a:visited { color: #204080; }
+span.index-where { font-size: 70%; }
+table.metadata-index { border-collapse: collapse;
+ background: #e8f0f8; color: #000000;
+ border: 1px solid #608090;
+ margin: .2em 0 0 0; }
+td.metadata-index { border-width: 1px; border-style: solid; }
+table.metadata-index a:link { color: #0000ff; }
+table.metadata-index a:visited { color: #204080; }
+
+/* Function signatures
+ * - sig* is used for the signature in the details section.
+ * - .summary-sig* is used for the signature in the summary
+ * table, and when listing property accessor functions.
+ * */
+.sig-name { color: #006080; }
+.sig-arg { color: #008060; }
+.sig-default { color: #602000; }
+.summary-sig { font-family: monospace; }
+.summary-sig-name { color: #006080; font-weight: bold; }
+table.summary a.summary-sig-name:link
+ { color: #006080; font-weight: bold; }
+table.summary a.summary-sig-name:visited
+ { color: #006080; font-weight: bold; }
+.summary-sig-arg { color: #006040; }
+.summary-sig-default { color: #501800; }
+
+/* Subclass list
+ */
+ul.subclass-list { display: inline; }
+ul.subclass-list li { display: inline; }
+
+/* To render variables, classes etc. like functions */
+table.summary .summary-name { color: #006080; font-weight: bold;
+ font-family: monospace; }
+table.summary
+ a.summary-name:link { color: #006080; font-weight: bold;
+ font-family: monospace; }
+table.summary
+ a.summary-name:visited { color: #006080; font-weight: bold;
+ font-family: monospace; }
+
+/* Variable values
+ * - In the 'variable details' sections, each varaible's value is
+ * listed in a 'pre.variable' box. The width of this box is
+ * restricted to 80 chars; if the value's repr is longer than
+ * this it will be wrapped, using a backslash marked with
+ * class 'variable-linewrap'. If the value's repr is longer
+ * than 3 lines, the rest will be ellided; and an ellipsis
+ * marker ('...' marked with 'variable-ellipsis') will be used.
+ * - If the value is a string, its quote marks will be marked
+ * with 'variable-quote'.
+ * - If the variable is a regexp, it is syntax-highlighted using
+ * the re* CSS classes.
+ */
+pre.variable { padding: .5em; margin: 0;
+ background: #dce4ec; color: #000000;
+ border: 1px solid #708890; }
+.variable-linewrap { color: #604000; font-weight: bold; }
+.variable-ellipsis { color: #604000; font-weight: bold; }
+.variable-quote { color: #604000; font-weight: bold; }
+.variable-group { color: #008000; font-weight: bold; }
+.variable-op { color: #604000; font-weight: bold; }
+.variable-string { color: #006030; }
+.variable-unknown { color: #a00000; font-weight: bold; }
+.re { color: #000000; }
+.re-char { color: #006030; }
+.re-op { color: #600000; }
+.re-group { color: #003060; }
+.re-ref { color: #404040; }
+
+/* Base tree
+ * - Used by class pages to display the base class hierarchy.
+ */
+pre.base-tree { font-size: 80%; margin: 0; }
+
+/* Frames-based table of contents headers
+ * - Consists of two frames: one for selecting modules; and
+ * the other listing the contents of the selected module.
+ * - h1.toc is used for each frame's heading
+ * - h2.toc is used for subheadings within each frame.
+ */
+h1.toc { text-align: center; font-size: 105%;
+ margin: 0; font-weight: bold;
+ padding: 0; }
+h2.toc { font-size: 100%; font-weight: bold;
+ margin: 0.5em 0 0 -0.3em; }
+
+/* Syntax Highlighting for Source Code
+ * - doctest examples are displayed in a 'pre.py-doctest' block.
+ * If the example is in a details table entry, then it will use
+ * the colors specified by the 'table pre.py-doctest' line.
+ * - Source code listings are displayed in a 'pre.py-src' block.
+ * Each line is marked with 'span.py-line' (used to draw a line
+ * down the left margin, separating the code from the line
+ * numbers). Line numbers are displayed with 'span.py-lineno'.
+ * The expand/collapse block toggle button is displayed with
+ * 'a.py-toggle' (Note: the CSS style for 'a.py-toggle' should not
+ * modify the font size of the text.)
+ * - If a source code page is opened with an anchor, then the
+ * corresponding code block will be highlighted. The code
+ * block's header is highlighted with 'py-highlight-hdr'; and
+ * the code block's body is highlighted with 'py-highlight'.
+ * - The remaining py-* classes are used to perform syntax
+ * highlighting (py-string for string literals, py-name for names,
+ * etc.)
+ */
+pre.py-doctest { padding: .5em; margin: 1em;
+ background: #e8f0f8; color: #000000;
+ border: 1px solid #708890; }
+table pre.py-doctest { background: #dce4ec;
+ color: #000000; }
+pre.py-src { border: 2px solid #000000;
+ background: #f0f0f0; color: #000000; }
+.py-line { border-left: 2px solid #000000;
+ margin-left: .2em; padding-left: .4em; }
+.py-lineno { font-style: italic; font-size: 90%;
+ padding-left: .5em; }
+a.py-toggle { text-decoration: none; }
+div.py-highlight-hdr { border-top: 2px solid #000000;
+ border-bottom: 2px solid #000000;
+ background: #d8e8e8; }
+div.py-highlight { border-bottom: 2px solid #000000;
+ background: #d0e0e0; }
+.py-prompt { color: #005050; font-weight: bold;}
+.py-more { color: #005050; font-weight: bold;}
+.py-string { color: #006030; }
+.py-comment { color: #003060; }
+.py-keyword { color: #600000; }
+.py-output { color: #404040; }
+.py-name { color: #000050; }
+.py-name:link { color: #000050 !important; }
+.py-name:visited { color: #000050 !important; }
+.py-number { color: #005000; }
+.py-defname { color: #000060; font-weight: bold; }
+.py-def-name { color: #000060; font-weight: bold; }
+.py-base-class { color: #000060; }
+.py-param { color: #000060; }
+.py-docstring { color: #006030; }
+.py-decorator { color: #804020; }
+/* Use this if you don't want links to names underlined: */
+/*a.py-name { text-decoration: none; }*/
+
+/* Graphs & Diagrams
+ * - These CSS styles are used for graphs & diagrams generated using
+ * Graphviz dot. 'img.graph-without-title' is used for bare
+ * diagrams (to remove the border created by making the image
+ * clickable).
+ */
+img.graph-without-title { border: none; }
+img.graph-with-title { border: 1px solid #000000; }
+span.graph-title { font-weight: bold; }
+span.graph-caption { }
+
+/* General-purpose classes
+ * - 'p.indent-wrapped-lines' defines a paragraph whose first line
+ * is not indented, but whose subsequent lines are.
+ * - The 'nomargin-top' class is used to remove the top margin (e.g.
+ * from lists). The 'nomargin' class is used to remove both the
+ * top and bottom margin (but not the left or right margin --
+ * for lists, that would cause the bullets to disappear.)
+ */
+p.indent-wrapped-lines { padding: 0 0 0 7em; text-indent: -7em;
+ margin: 0; }
+.nomargin-top { margin-top: 0; }
+.nomargin { margin-top: 0; margin-bottom: 0; }
+
+/* HTML Log */
+div.log-block { padding: 0; margin: .5em 0 .5em 0;
+ background: #e8f0f8; color: #000000;
+ border: 1px solid #000000; }
+div.log-error { padding: .1em .3em .1em .3em; margin: 4px;
+ background: #ffb0b0; color: #000000;
+ border: 1px solid #000000; }
+div.log-warning { padding: .1em .3em .1em .3em; margin: 4px;
+ background: #ffffb0; color: #000000;
+ border: 1px solid #000000; }
+div.log-info { padding: .1em .3em .1em .3em; margin: 4px;
+ background: #b0ffb0; color: #000000;
+ border: 1px solid #000000; }
+h2.log-hdr { background: #70b0ff; color: #000000;
+ margin: 0; padding: 0em 0.5em 0em 0.5em;
+ border-bottom: 1px solid #000000; font-size: 110%; }
+p.log { font-weight: bold; margin: .5em 0 .5em 0; }
+tr.opt-changed { color: #000000; font-weight: bold; }
+tr.opt-default { color: #606060; }
+pre.log { margin: 0; padding: 0; padding-left: 1em; }
diff --git a/docs/epydoc.js b/docs/epydoc.js
new file mode 100644
index 0000000..e787dbc
--- /dev/null
+++ b/docs/epydoc.js
@@ -0,0 +1,293 @@
+function toggle_private() {
+ // Search for any private/public links on this page. Store
+ // their old text in "cmd," so we will know what action to
+ // take; and change their text to the opposite action.
+ var cmd = "?";
+ var elts = document.getElementsByTagName("a");
+ for(var i=0; i";
+ s += " ";
+ for (var i=0; i... ";
+ elt.innerHTML = s;
+ }
+}
+
+function toggle(id) {
+ elt = document.getElementById(id+"-toggle");
+ if (elt.innerHTML == "-")
+ collapse(id);
+ else
+ expand(id);
+ return false;
+}
+
+function highlight(id) {
+ var elt = document.getElementById(id+"-def");
+ if (elt) elt.className = "py-highlight-hdr";
+ var elt = document.getElementById(id+"-expanded");
+ if (elt) elt.className = "py-highlight";
+ var elt = document.getElementById(id+"-collapsed");
+ if (elt) elt.className = "py-highlight";
+}
+
+function num_lines(s) {
+ var n = 1;
+ var pos = s.indexOf("\n");
+ while ( pos > 0) {
+ n += 1;
+ pos = s.indexOf("\n", pos+1);
+ }
+ return n;
+}
+
+// Collapse all blocks that mave more than `min_lines` lines.
+function collapse_all(min_lines) {
+ var elts = document.getElementsByTagName("div");
+ for (var i=0; i 0)
+ if (elt.id.substring(split, elt.id.length) == "-expanded")
+ if (num_lines(elt.innerHTML) > min_lines)
+ collapse(elt.id.substring(0, split));
+ }
+}
+
+function expandto(href) {
+ var start = href.indexOf("#")+1;
+ if (start != 0 && start != href.length) {
+ if (href.substring(start, href.length) != "-") {
+ collapse_all(4);
+ pos = href.indexOf(".", start);
+ while (pos != -1) {
+ var id = href.substring(start, pos);
+ expand(id);
+ pos = href.indexOf(".", pos+1);
+ }
+ var id = href.substring(start, href.length);
+ expand(id);
+ highlight(id);
+ }
+ }
+}
+
+function kill_doclink(id) {
+ var parent = document.getElementById(id);
+ parent.removeChild(parent.childNodes.item(0));
+}
+function auto_kill_doclink(ev) {
+ if (!ev) var ev = window.event;
+ if (!this.contains(ev.toElement)) {
+ var parent = document.getElementById(this.parentID);
+ parent.removeChild(parent.childNodes.item(0));
+ }
+}
+
+function doclink(id, name, targets_id) {
+ var elt = document.getElementById(id);
+
+ // If we already opened the box, then destroy it.
+ // (This case should never occur, but leave it in just in case.)
+ if (elt.childNodes.length > 1) {
+ elt.removeChild(elt.childNodes.item(0));
+ }
+ else {
+ // The outer box: relative + inline positioning.
+ var box1 = document.createElement("div");
+ box1.style.position = "relative";
+ box1.style.display = "inline";
+ box1.style.top = 0;
+ box1.style.left = 0;
+
+ // A shadow for fun
+ var shadow = document.createElement("div");
+ shadow.style.position = "absolute";
+ shadow.style.left = "-1.3em";
+ shadow.style.top = "-1.3em";
+ shadow.style.background = "#404040";
+
+ // The inner box: absolute positioning.
+ var box2 = document.createElement("div");
+ box2.style.position = "relative";
+ box2.style.border = "1px solid #a0a0a0";
+ box2.style.left = "-.2em";
+ box2.style.top = "-.2em";
+ box2.style.background = "white";
+ box2.style.padding = ".3em .4em .3em .4em";
+ box2.style.fontStyle = "normal";
+ box2.onmouseout=auto_kill_doclink;
+ box2.parentID = id;
+
+ // Get the targets
+ var targets_elt = document.getElementById(targets_id);
+ var targets = targets_elt.getAttribute("targets");
+ var links = "";
+ target_list = targets.split(",");
+ for (var i=0; i" +
+ target[0] + " ";
+ }
+
+ // Put it all together.
+ elt.insertBefore(box1, elt.childNodes.item(0));
+ //box1.appendChild(box2);
+ box1.appendChild(shadow);
+ shadow.appendChild(box2);
+ box2.innerHTML =
+ "Which "+name+" do you want to see documentation for?" +
+ "";
+ }
+ return false;
+}
+
+function get_anchor() {
+ var href = location.href;
+ var start = href.indexOf("#")+1;
+ if ((start != 0) && (start != href.length))
+ return href.substring(start, href.length);
+ }
+function redirect_url(dottedName) {
+ // Scan through each element of the "pages" list, and check
+ // if "name" matches with any of them.
+ for (var i=0; i-m" or "-c";
+ // extract the portion & compare it to dottedName.
+ var pagename = pages[i].substring(0, pages[i].length-2);
+ if (pagename == dottedName.substring(0,pagename.length)) {
+
+ // We've found a page that matches `dottedName`;
+ // construct its URL, using leftover `dottedName`
+ // content to form an anchor.
+ var pagetype = pages[i].charAt(pages[i].length-1);
+ var url = pagename + ((pagetype=="m")?"-module.html":
+ "-class.html");
+ if (dottedName.length > pagename.length)
+ url += "#" + dottedName.substring(pagename.length+1,
+ dottedName.length);
+ return url;
+ }
+ }
+ }
diff --git a/docs/frames.html b/docs/frames.html
new file mode 100644
index 0000000..2556081
--- /dev/null
+++ b/docs/frames.html
@@ -0,0 +1,17 @@
+
+
+
+
+ API Documentation
+
+
+
+
+
+
+
+
+
diff --git a/docs/help.html b/docs/help.html
new file mode 100644
index 0000000..b4ddb60
--- /dev/null
+++ b/docs/help.html
@@ -0,0 +1,268 @@
+
+
+
+
+ Help
+
+
+
+
+
+
+
+
+
+ API Documentation
+
+ This document contains the API (Application Programming Interface)
+documentation for this project. Documentation for the Python
+objects defined by the project is divided into separate pages for each
+package, module, and class. The API documentation also includes two
+pages containing information about the project as a whole: a trees
+page, and an index page.
+
+ Object Documentation
+
+ Each Package Documentation page contains:
+
+ A description of the package.
+ A list of the modules and sub-packages contained by the
+ package.
+ A summary of the classes defined by the package.
+ A summary of the functions defined by the package.
+ A summary of the variables defined by the package.
+ A detailed description of each function defined by the
+ package.
+ A detailed description of each variable defined by the
+ package.
+
+
+ Each Module Documentation page contains:
+
+ A description of the module.
+ A summary of the classes defined by the module.
+ A summary of the functions defined by the module.
+ A summary of the variables defined by the module.
+ A detailed description of each function defined by the
+ module.
+ A detailed description of each variable defined by the
+ module.
+
+
+ Each Class Documentation page contains:
+
+ A class inheritance diagram.
+ A list of known subclasses.
+ A description of the class.
+ A summary of the methods defined by the class.
+ A summary of the instance variables defined by the class.
+ A summary of the class (static) variables defined by the
+ class.
+ A detailed description of each method defined by the
+ class.
+ A detailed description of each instance variable defined by the
+ class.
+ A detailed description of each class (static) variable defined
+ by the class.
+
+
+ Project Documentation
+
+ The Trees page contains the module and class hierarchies:
+
+ The module hierarchy lists every package and module, with
+ modules grouped into packages. At the top level, and within each
+ package, modules and sub-packages are listed alphabetically.
+ The class hierarchy lists every class, grouped by base
+ class. If a class has more than one base class, then it will be
+ listed under each base class. At the top level, and under each base
+ class, classes are listed alphabetically.
+
+
+ The Index page contains indices of terms and
+ identifiers:
+
+ The term index lists every term indexed by any object's
+ documentation. For each term, the index provides links to each
+ place where the term is indexed.
+ The identifier index lists the (short) name of every package,
+ module, class, method, function, variable, and parameter. For each
+ identifier, the index provides a short description, and a link to
+ its documentation.
+
+
+ The Table of Contents
+
+ The table of contents occupies the two frames on the left side of
+the window. The upper-left frame displays the project
+contents , and the lower-left frame displays the module
+contents :
+
+
+
+
+ Project Contents ...
+
+ API Documentation Frame
+
+
+
+
+ Module Contents ...
+
+
+
+
+ The project contents frame contains a list of all packages
+and modules that are defined by the project. Clicking on an entry
+will display its contents in the module contents frame. Clicking on a
+special entry, labeled "Everything," will display the contents of
+the entire project.
+
+ The module contents frame contains a list of every
+submodule, class, type, exception, function, and variable defined by a
+module or package. Clicking on an entry will display its
+documentation in the API documentation frame. Clicking on the name of
+the module, at the top of the frame, will display the documentation
+for the module itself.
+
+ The "frames " and "no frames " buttons below the top
+navigation bar can be used to control whether the table of contents is
+displayed or not.
+
+ The Navigation Bar
+
+ A navigation bar is located at the top and bottom of every page.
+It indicates what type of page you are currently viewing, and allows
+you to go to related pages. The following table describes the labels
+on the navigation bar. Note that not some labels (such as
+[Parent]) are not displayed on all pages.
+
+
+
+ Label
+ Highlighted when...
+ Links to...
+
+ [Parent]
+ (never highlighted)
+ the parent of the current package
+ [Package]
+ viewing a package
+ the package containing the current object
+
+ [Module]
+ viewing a module
+ the module containing the current object
+
+ [Class]
+ viewing a class
+ the class containing the current object
+ [Trees]
+ viewing the trees page
+ the trees page
+ [Index]
+ viewing the index page
+ the index page
+ [Help]
+ viewing the help page
+ the help page
+
+
+ The "show private " and "hide private " buttons below
+the top navigation bar can be used to control whether documentation
+for private objects is displayed. Private objects are usually defined
+as objects whose (short) names begin with a single underscore, but do
+not end with an underscore. For example, "_x
",
+"__pprint
", and "epydoc.epytext._tokenize
"
+are private objects; but "re.sub
",
+"__init__
", and "type_
" are not. However,
+if a module defines the "__all__
" variable, then its
+contents are used to decide which objects are private.
+
+ A timestamp below the bottom navigation bar indicates when each
+page was last updated.
+
+
+
+
+
+
+
diff --git a/docs/identifier-index.html b/docs/identifier-index.html
new file mode 100644
index 0000000..bc4bc78
--- /dev/null
+++ b/docs/identifier-index.html
@@ -0,0 +1,260 @@
+
+
+
+
+ Identifier Index
+
+
+
+
+
+
+
+
+
+
+Identifier Index
+
+[
+ A
+ B
+ C
+ D
+ E
+ F
+ G
+ H
+ I
+ J
+ K
+ L
+ M
+ N
+ O
+ P
+ Q
+ R
+ S
+ T
+ U
+ V
+ W
+ X
+ Y
+ Z
+ _
+]
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/docs/index.html b/docs/index.html
new file mode 100644
index 0000000..2556081
--- /dev/null
+++ b/docs/index.html
@@ -0,0 +1,17 @@
+
+
+
+
+ API Documentation
+
+
+
+
+
+
+
+
+
diff --git a/docs/module-tree.html b/docs/module-tree.html
new file mode 100644
index 0000000..b1b3365
--- /dev/null
+++ b/docs/module-tree.html
@@ -0,0 +1,110 @@
+
+
+
+
+ Module Hierarchy
+
+
+
+
+
+
+
+
+
+ [ Module Hierarchy
+ | Class Hierarchy ]
+
+Module Hierarchy
+
+
+
+
+
+
+
+
diff --git a/docs/redirect.html b/docs/redirect.html
new file mode 100644
index 0000000..3674f1d
--- /dev/null
+++ b/docs/redirect.html
@@ -0,0 +1,38 @@
+Epydoc Redirect Page
+
+
+
+
+
+
+
+
+Epydoc Auto-redirect page
+
+When javascript is enabled, this page will redirect URLs of
+the form redirect.html#dotted.name to the
+documentation for the object with the given fully-qualified
+dotted name.
+
+
+
+
+
+
diff --git a/docs/toc-browsermobproxy-module.html b/docs/toc-browsermobproxy-module.html
new file mode 100644
index 0000000..ad8c4f8
--- /dev/null
+++ b/docs/toc-browsermobproxy-module.html
@@ -0,0 +1,32 @@
+
+
+
+
+ browsermobproxy
+
+
+
+
+
+Module browsermobproxy
+
+ Variables
+ Client Server
+[hide private ]
+
+
+
+
diff --git a/docs/toc-browsermobproxy.client-module.html b/docs/toc-browsermobproxy.client-module.html
new file mode 100644
index 0000000..82ea832
--- /dev/null
+++ b/docs/toc-browsermobproxy.client-module.html
@@ -0,0 +1,31 @@
+
+
+
+
+ client
+
+
+
+
+
+Module client
+
+ Classes
+ Client
+[hide private ]
+
+
+
+
diff --git a/docs/toc-browsermobproxy.server-module.html b/docs/toc-browsermobproxy.server-module.html
new file mode 100644
index 0000000..731a9e4
--- /dev/null
+++ b/docs/toc-browsermobproxy.server-module.html
@@ -0,0 +1,31 @@
+
+
+
+
+ server
+
+
+
+
+
+Module server
+
+ Classes
+ Server
+[hide private ]
+
+
+
+
diff --git a/docs/toc-everything.html b/docs/toc-everything.html
new file mode 100644
index 0000000..001f345
--- /dev/null
+++ b/docs/toc-everything.html
@@ -0,0 +1,35 @@
+
+
+
+
+ Everything
+
+
+
+
+
+Everything
+
+ All Classes
+ browsermobproxy.client.Client browsermobproxy.server.Server All Variables
+ browsermobproxy.Client browsermobproxy.Server
+[hide private ]
+
+
+
+
diff --git a/docs/toc.html b/docs/toc.html
new file mode 100644
index 0000000..8706e03
--- /dev/null
+++ b/docs/toc.html
@@ -0,0 +1,35 @@
+
+
+
+
+ Table of Contents
+
+
+
+
+
+Table of Contents
+
+ Everything
+
+ Modules
+ browsermobproxy browsermobproxy.client browsermobproxy.server
+ [hide private ]
+
+
+
+
diff --git a/index.html b/index.html
new file mode 100644
index 0000000..a5d803e
--- /dev/null
+++ b/index.html
@@ -0,0 +1,25 @@
+
+
+
+ Python Browsermob Proxy Library
+
+
+
+
+
+
Python Browsermob Proxy Library
+
+ This is the Python Library for interaction with the Browsermob Proxy. It allows us to create a proxy, set references and generate HAR representations. For more details read the Pydocs . Note that this will only work with Selenium 2.17 onwards.
+
+
+
+
Releases
+
0.0.1
+
+
+
+
+
+
diff --git a/stylesheets/style.css b/stylesheets/style.css
new file mode 100644
index 0000000..f47c480
--- /dev/null
+++ b/stylesheets/style.css
@@ -0,0 +1,21 @@
+body {
+ font: 14px "Lucida Grande", Helvetica, Arial, sans-serif;
+ background: gray;
+ color: white;
+}
+
+a {
+ color: #00B7FF;
+}
+.container {
+ margin: 0 auto;
+ width: 850px
+}
+
+.background {
+ background: #CACACA url();
+ display:block;
+ width:100%;
+ height:100px;
+ position: relative;
+ top:0px;}
From 78b43d926083828f5ec93331159985b4e25ca7c4 Mon Sep 17 00:00:00 2001
From: AutomatedTester
Date: Mon, 16 Jan 2012 20:55:24 +0000
Subject: [PATCH 2/9] added an example
---
index.html | 22 ++++++++++++++++++++++
stylesheets/style.css | 13 +++++++++++++
2 files changed, 35 insertions(+)
diff --git a/index.html b/index.html
index a5d803e..3d5e292 100644
--- a/index.html
+++ b/index.html
@@ -11,7 +11,29 @@ Python Browsermob Proxy Library
This is the Python Library for interaction with the Browsermob Proxy. It allows us to create a proxy, set references and generate HAR representations. For more details read the Pydocs . Note that this will only work with Selenium 2.17 onwards.
+
+
Example
+
+
+ from browsermobproxy import Server
+ server = Server("path/to/browsermob-proxy")
+ server.start()
+ proxy = server.create_proxy
+
+ from selenium import webdriver
+ profile = webdriver.FirefoxProfile()
+ profile.set_proxy(proxy.selenium_proxy())
+ driver = webdriver.Firefox(firefox_profile=profile)
+ proxy.new_har("google")
+ driver.get("http://www.google.co.uk")
+ proxy.har # returns a HAR JSON blob
+
+ proxy.stop()
+ driver.quit()
+
+
+
Releases
0.0.1
diff --git a/stylesheets/style.css b/stylesheets/style.css
index f47c480..bbc82d3 100644
--- a/stylesheets/style.css
+++ b/stylesheets/style.css
@@ -12,6 +12,19 @@ a {
width: 850px
}
+pre {
+ font: 12px monaco, monospace;
+ margin: 10px;
+ padding: 10px;
+ border: 1px solid #eee;
+ border-bottom-color: #ddd;
+ -webkit-border-radius: 2px;
+ -moz-border-radius: 2px;
+ -webkit-box-shadow: inset 0 0 10px #eee;
+ -moz-box-shadow: inset 0 0 10px #eee;
+ overflow-x: auto;
+}
+
.background {
background: #CACACA url();
display:block;
From 0ef15046173fa1ddde09690decb71f4b67ebe8ff Mon Sep 17 00:00:00 2001
From: AutomatedTester
Date: Mon, 16 Jan 2012 21:22:50 +0000
Subject: [PATCH 3/9] fixed typo
---
index.html | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/index.html b/index.html
index 3d5e292..0e06452 100644
--- a/index.html
+++ b/index.html
@@ -36,7 +36,7 @@ Example
Releases
- 0.0.1
+ 0.0.1
From 2ce0f00a322ed306331209901d99e048dc24ebfa Mon Sep 17 00:00:00 2001
From: AutomatedTester
Date: Tue, 17 Jan 2012 20:06:47 +0000
Subject: [PATCH 4/9] fixed typo
---
index.html | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/index.html b/index.html
index 0e06452..a563428 100644
--- a/index.html
+++ b/index.html
@@ -42,6 +42,6 @@ Releases
-
+