141 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
		
		
			
		
	
	
			141 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
|   | # Protocol Buffers - Code Example
 | ||
|  | 
 | ||
|  | This directory contains example code that uses Protocol Buffers to manage an | ||
|  | address book. Two programs are provided for each supported language. The | ||
|  | add_person example adds a new person to an address book, prompting the user to | ||
|  | input the person's information. The list_people example lists people already in | ||
|  | the address book. The examples use the exact same format in all three languages, | ||
|  | so you can, for example, use add_person_java to create an address book and then | ||
|  | use list_people_python to read it. | ||
|  | 
 | ||
|  | These examples are part of the Protocol Buffers tutorial, located at: | ||
|  |   https://developers.google.com/protocol-buffers/docs/tutorials | ||
|  | 
 | ||
|  | ## Build the example using bazel
 | ||
|  | 
 | ||
|  | The example requires bazel 0.5.4 or newer to build. You can download/install | ||
|  | the latest version of bazel from bazel's release page: | ||
|  | 
 | ||
|  |     https://github.com/bazelbuild/bazel/releases | ||
|  | 
 | ||
|  | Once you have bazel installed, simply run the following command in this examples | ||
|  | directory to build the code: | ||
|  | 
 | ||
|  |     $ bazel build :all | ||
|  | 
 | ||
|  | Then you can run the built binary: | ||
|  | 
 | ||
|  |     $ bazel-bin/add_person_cpp addressbook.data | ||
|  | 
 | ||
|  | To use protobuf in your own bazel project, please follow instructions in the | ||
|  | [BUILD](BUILD) file and [WORKSPACE](WORKSPACE) file. | ||
|  | 
 | ||
|  | ## Build the example using make
 | ||
|  | 
 | ||
|  | You must install the protobuf package before you can build it using make. The | ||
|  | minimum requirement is to install protocol compiler (i.e., the protoc binary) | ||
|  | and the protobuf runtime for the language you want to build. | ||
|  | 
 | ||
|  | You can simply run "make" to build the example for all languages (except for | ||
|  | Go). However, since different language has different installation requirement, | ||
|  | it will likely fail. It's better to follow individual instructions below to | ||
|  | build only the language you are interested in. | ||
|  | 
 | ||
|  | ### C++
 | ||
|  | 
 | ||
|  | You can follow instructions in [../src/README.md](../src/README.md) to install | ||
|  | protoc and protobuf C++ runtime from source. | ||
|  | 
 | ||
|  | Then run "make cpp" in this examples directory to build the C++ example. It | ||
|  | will create two executables: add_person_cpp and list_people_cpp. These programs | ||
|  | simply take an address book file as their parameter. The add_person_cpp | ||
|  | programs will create the file if it doesn't already exist. | ||
|  | 
 | ||
|  | To run the examples: | ||
|  | 
 | ||
|  |     $ ./add_person_cpp addressbook.data | ||
|  |     $ ./list_people_cpp addressbook.data | ||
|  | 
 | ||
|  | Note that on some platforms you may have to edit the Makefile and remove | ||
|  | "-lpthread" from the linker commands (perhaps replacing it with something else). | ||
|  | We didn't do this automatically because we wanted to keep the example simple. | ||
|  | 
 | ||
|  | ### Python
 | ||
|  | 
 | ||
|  | Follow instructions in [../README.md](../README.md) to install protoc and then | ||
|  | follow [../python/README.md](../python/README.md) to install protobuf python | ||
|  | runtime from source. You can also install python runtime using pip: | ||
|  | 
 | ||
|  |     $ pip install protobuf | ||
|  | 
 | ||
|  | Make sure the runtime version is the same as protoc binary, or it may not work. | ||
|  | 
 | ||
|  | After you have install both protoc and python runtime, run "make python" to | ||
|  | build two executables (shell scripts actually): add_person_python and | ||
|  | list_people_python. They work the same way as the C++ executables. | ||
|  | 
 | ||
|  | ### Java
 | ||
|  | 
 | ||
|  | Follow instructions in [../README.md](../README.md) to install protoc and then | ||
|  | download protobuf Java runtime .jar file from maven: | ||
|  | 
 | ||
|  |     https://mvnrepository.com/artifact/com.google.protobuf/protobuf-java | ||
|  | 
 | ||
|  | Then run the following: | ||
|  | 
 | ||
|  |     $ export CLASSPATH=/path/to/protobuf-java-[version].jar | ||
|  |     $ make java | ||
|  | 
 | ||
|  | This will create the add_person_java/list_people_java executables (shell | ||
|  | scripts) and can be used to create/display an address book data file. | ||
|  | 
 | ||
|  | ### Go
 | ||
|  | 
 | ||
|  | Follow instructions in [../README.md](../README.md) to install protoc. Then | ||
|  | install the Go protoc plugin (protoc-gen-go): | ||
|  | 
 | ||
|  |     $ go install google.golang.org/protobuf/cmd/protoc-gen-go@latest | ||
|  | 
 | ||
|  | The "go install" command will install protoc-gen-go into the GOBIN | ||
|  | directory.  You can set the $GOBIN environment variable before | ||
|  | running "go install" to change the install location.  Make sure the | ||
|  | install directory is in your shell $PATH. | ||
|  | 
 | ||
|  | Build the Go samples with "make go".  This creates the following | ||
|  | executable files in the current directory: | ||
|  | 
 | ||
|  |     add_person_go      list_people_go | ||
|  | 
 | ||
|  | To run the example: | ||
|  | 
 | ||
|  |     ./add_person_go addressbook.data | ||
|  | 
 | ||
|  | to add a person to the protocol buffer encoded file addressbook.data.  The file | ||
|  | is created if it does not exist.  To view the data, run: | ||
|  | 
 | ||
|  |     ./list_people_go addressbook.data | ||
|  | 
 | ||
|  | Observe that the C++, Python, Java, and Dart examples in this directory run in a | ||
|  | similar way and can view/modify files created by the Go example and vice | ||
|  | versa. | ||
|  | 
 | ||
|  | ### Dart
 | ||
|  | 
 | ||
|  | First, follow the instructions in [../README.md](../README.md) to install the Protocol Buffer Compiler (protoc). | ||
|  | 
 | ||
|  | Then, install the Dart Protocol Buffer plugin as described [here](https://github.com/dart-lang/dart-protoc-plugin#how-to-build-and-use). | ||
|  | Note, the executable `bin/protoc-gen-dart` must be in your `PATH` for `protoc` to find it. | ||
|  | 
 | ||
|  | Build the Dart samples in this directory with `make dart`. | ||
|  | 
 | ||
|  | To run the examples: | ||
|  | 
 | ||
|  | ```sh | ||
|  | $ dart add_person.dart addressbook.data | ||
|  | $ dart list_people.dart addressbook.data | ||
|  | ``` | ||
|  | 
 | ||
|  | The two programs take a protocol buffer encoded file as their parameter. | ||
|  | The first can be used to add a person to the file. The file is created | ||
|  | if it does not exist. The second displays the data in the file. |