blob: d37139460893d740ce25ebdf8ffaac29097c0b98 [file] [log] [blame]
Jens Geyer0e87c462013-06-18 22:25:07 +02001package main
Christian Lavoieafc6d8f2011-02-20 02:39:19 +00002
3/*
4 * Licensed to the Apache Software Foundation (ASF) under one
5 * or more contributor license agreements. See the NOTICE file
6 * distributed with this work for additional information
7 * regarding copyright ownership. The ASF licenses this file
8 * to you under the Apache License, Version 2.0 (the
9 * "License"); you may not use this file except in compliance
10 * with the License. You may obtain a copy of the License at
11 *
12 * http://www.apache.org/licenses/LICENSE-2.0
13 *
14 * Unless required by applicable law or agreed to in writing,
15 * software distributed under the License is distributed on an
16 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17 * KIND, either express or implied. See the License for the
18 * specific language governing permissions and limitations
19 * under the License.
20 */
21
Christian Lavoieafc6d8f2011-02-20 02:39:19 +000022import (
Jens Geyer0e87c462013-06-18 22:25:07 +020023 "flag"
24 "fmt"
25 "git.apache.org/thrift.git/lib/go/thrift"
26 "os"
Christian Lavoieafc6d8f2011-02-20 02:39:19 +000027)
28
29func Usage() {
Jens Geyer0e87c462013-06-18 22:25:07 +020030 fmt.Fprint(os.Stderr, "Usage of ", os.Args[0], ":\n")
31 flag.PrintDefaults()
32 fmt.Fprint(os.Stderr, "\n")
Christian Lavoieafc6d8f2011-02-20 02:39:19 +000033}
34
35func main() {
Jens Geyer0e87c462013-06-18 22:25:07 +020036 flag.Usage = Usage
37 server := flag.Bool("server", false, "Run server")
38 protocol := flag.String("P", "binary", "Specify the protocol (binary, compact, simplejson)")
39 framed := flag.Bool("framed", false, "Use framed transport")
Jens Geyer44b19df2013-07-26 23:05:00 +020040 buffered := flag.Bool("buffered", false, "Use buffered transport")
41 addr := flag.String("addr", "localhost:9090", "Address to listen to")
Jens Geyer0e87c462013-06-18 22:25:07 +020042
43 flag.Parse()
44
45 var protocolFactory thrift.TProtocolFactory
46 switch *protocol {
47 case "compact":
48 protocolFactory = thrift.NewTCompactProtocolFactory()
49 case "simplejson":
50 protocolFactory = thrift.NewTSimpleJSONProtocolFactory()
51 case "json":
52 protocolFactory = thrift.NewTJSONProtocolFactory()
53 case "binary", "":
54 protocolFactory = thrift.NewTBinaryProtocolFactoryDefault()
55 default:
56 fmt.Fprint(os.Stderr, "Invalid protocol specified", protocol, "\n")
57 Usage()
58 os.Exit(1)
59 }
Jens Geyer44b19df2013-07-26 23:05:00 +020060
61 var transportFactory thrift.TTransportFactory
62 if *buffered {
63 transportFactory = thrift.NewTBufferedTransportFactory(8192)
64 } else {
65 transportFactory = thrift.NewTTransportFactory()
66 }
67
Jens Geyer0e87c462013-06-18 22:25:07 +020068 if *framed {
69 transportFactory = thrift.NewTFramedTransportFactory(transportFactory)
70 }
71
72 if *server {
Jens Geyer44b19df2013-07-26 23:05:00 +020073 if err := runServer(transportFactory, protocolFactory, *addr); err != nil {
Jens Geyer0e87c462013-06-18 22:25:07 +020074 fmt.Println("error running server:", err)
75 }
76 } else {
Jens Geyer44b19df2013-07-26 23:05:00 +020077 if err := runClient(transportFactory, protocolFactory, *addr); err != nil {
Jens Geyer0e87c462013-06-18 22:25:07 +020078 fmt.Println("error running client:", err)
79 }
80 }
Christian Lavoieafc6d8f2011-02-20 02:39:19 +000081}