3 # Copyright (c) 2013 The Chromium Authors. All rights reserved.
4 # Use of this source code is governed by a BSD-style license that can be
5 # found in the LICENSE file.
7 """Command line tool for forwarding ports from a device to the host.
9 Allows an Android device to connect to services running on the host machine,
10 i.e., "adb forward" in reverse. Requires |host_forwarder| and |device_forwarder|
19 from pylib
import constants
20 from pylib
import forwarder
21 from pylib
.device
import adb_wrapper
22 from pylib
.device
import device_utils
23 from pylib
.utils
import run_tests_helper
27 parser
= optparse
.OptionParser(usage
='Usage: %prog [options] device_port '
28 'host_port [device_port_2 host_port_2] ...',
30 parser
.add_option('-v',
35 help='Verbose level (multiple times for more)')
36 parser
.add_option('--device',
37 help='Serial number of device we should use.')
38 parser
.add_option('--debug', action
='store_const', const
='Debug',
39 dest
='build_type', default
='Release',
40 help='Use Debug build of host tools instead of Release.')
42 options
, args
= parser
.parse_args(argv
)
43 run_tests_helper
.SetLogLevel(options
.verbose_count
)
45 if len(args
) < 2 or not len(args
) % 2:
46 parser
.error('Need even number of port pairs')
50 port_pairs
= map(int, args
[1:])
51 port_pairs
= zip(port_pairs
[::2], port_pairs
[1::2])
53 parser
.error('Bad port number')
56 devices
= device_utils
.DeviceUtils
.HealthyDevices()
59 if options
.device
not in [str(d
) for d
in devices
]:
60 raise Exception('Error: %s not in attached devices %s' % (options
.device
,
62 devices
= [options
.device
]
65 raise Exception('Error: no connected devices')
66 logging
.info('No device specified. Defaulting to %s', devices
[0])
69 constants
.SetBuildType(options
.build_type
)
71 forwarder
.Forwarder
.Map(port_pairs
, device
)
74 except KeyboardInterrupt:
77 forwarder
.Forwarder
.UnmapAllDevicePorts(device
)
79 if __name__
== '__main__':