Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
c934d1d1
Unverified
Commit
c934d1d1
authored
Apr 02, 2018
by
Feng Xiao
Committed by
GitHub
Apr 02, 2018
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #4452 from xfxyjwf/doc
Update instructions about getting protobuf source.
parents
aab0f898
014e76e2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
85 additions
and
71 deletions
+85
-71
README.md
cmake/README.md
+14
-6
README.md
src/README.md
+71
-65
No files found.
cmake/README.md
View file @
c934d1d1
...
@@ -41,9 +41,16 @@ Good. Now you are ready to continue.
...
@@ -41,9 +41,16 @@ Good. Now you are ready to continue.
Getting Sources
Getting Sources
===============
===============
You can get the latest stable source packages from the
You can get the latest stable source packages from the release page:
[
releases
](
https://github.com/google/protobuf/releases
)
page.
Or you can type:
https://github.com/google/protobuf/releases/latest
For example: if you only need C++, download
`protobuf-cpp-[VERSION].tar.gz`
; if
you need C++ and Java, download
`protobuf-java-[VERSION].tar.gz`
(every package
contains C++ source already); if you need C++ and multiple other languages,
download
`protobuf-all-[VERSION].tar.gz`
.
Or you can use git to clone from protobuf git repository.
C:\Path\to> git clone -b [release_tag] https://github.com/google/protobuf.git
C:\Path\to> git clone -b [release_tag] https://github.com/google/protobuf.git
...
@@ -55,7 +62,8 @@ Go to the project folder:
...
@@ -55,7 +62,8 @@ Go to the project folder:
C:\Path\to>cd protobuf
C:\Path\to>cd protobuf
C:\Path\to\protobuf>
C:\Path\to\protobuf>
Remember to update any submodules:
Remember to update any submodules if you are using git clone (you can skip this
step if you are using a release .tar.gz or .zip package):
```
console
```
console
C:\Path\to>
git submodule update
--init
--recursive
C:\Path\to>
git submodule update
--init
--recursive
...
@@ -63,7 +71,7 @@ C:\Path\to> git submodule update --init --recursive
...
@@ -63,7 +71,7 @@ C:\Path\to> git submodule update --init --recursive
Now go to
*cmake*
folder in protobuf sources:
Now go to
*cmake*
folder in protobuf sources:
C:\Path\to\protobuf
\gmock>cd ..\
cmake
C:\Path\to\protobuf
>cd
cmake
C:\Path\to\protobuf\cmake>
C:\Path\to\protobuf\cmake>
Good. Now you are ready to
*CMake*
configuration.
Good. Now you are ready to
*CMake*
configuration.
...
@@ -113,7 +121,7 @@ It will generate *nmake* *Makefile* in current directory.
...
@@ -113,7 +121,7 @@ It will generate *nmake* *Makefile* in current directory.
To create
*Visual Studio*
solution file:
To create
*Visual Studio*
solution file:
C:\Path\to\protobuf\cmake\build>mkdir solution & cd solution
C:\Path\to\protobuf\cmake\build>mkdir solution & cd solution
C:\Path\to\protobuf\cmake\build\solution>cmake -G "Visual Studio 1
2 2013
Win64" ^
C:\Path\to\protobuf\cmake\build\solution>cmake -G "Visual Studio 1
4 2015
Win64" ^
-DCMAKE_INSTALL_PREFIX=../../../../install ^
-DCMAKE_INSTALL_PREFIX=../../../../install ^
../..
../..
...
...
src/README.md
View file @
c934d1d1
...
@@ -19,25 +19,31 @@ To build protobuf from source, the following tools are needed:
...
@@ -19,25 +19,31 @@ To build protobuf from source, the following tools are needed:
*
g++
*
g++
*
unzip
*
unzip
On Ubuntu, you can install them with:
On Ubuntu
/Debian
, you can install them with:
$ sudo apt-get install autoconf automake libtool curl make g++ unzip
$ sudo apt-get install autoconf automake libtool curl make g++ unzip
On other platforms, please use the corresponding package managing tool to
On other platforms, please use the corresponding package managing tool to
install them before proceeding.
install them before proceeding.
If you get the source from github, you need to generate the configure script
To get the source, download one of the release .tar.gz or .zip packages in the
first
:
release page
:
$ git submodule update --init --recursive
https://github.com/google/protobuf/releases/latest
$ ./autogen.sh
For example: if you only need C++, download
`protobuf-cpp-[VERSION].tar.gz`
; if
you need C++ and Java, download
`protobuf-java-[VERSION].tar.gz`
(every package
contains C++ source already); if you need C++ and multiple other languages,
download
`protobuf-all-[VERSION].tar.gz`
.
This will download gmock source (which is used for C++ Protocol Buffer
You can also get the source by "git clone" our git repository. Make sure you
unit-tests) to the current directory and run automake, autoconf, etc.
have also cloned the submodules and generated the configure script (skip this
to generate the configure script and various template makefiles.
if you are using a release .tar.gz or .zip package):
You can skip this step if you are using a release package (which already
$ git clone https://github.com/google/protobuf.git
contains gmock and the configure script).
$ cd protobuf
$ git submodule update --init --recursive
$ ./autogen.sh
To build and install the C++ Protocol Buffer runtime and the Protocol
To build and install the C++ Protocol Buffer runtime and the Protocol
Buffer compiler (protoc) execute the following:
Buffer compiler (protoc) execute the following:
...
@@ -55,122 +61,122 @@ Proceed at your own risk.
...
@@ -55,122 +61,122 @@ Proceed at your own risk.
For advanced usage information on configure and make, please refer to the
For advanced usage information on configure and make, please refer to the
autoconf documentation:
autoconf documentation:
http://www.gnu.org/software/autoconf/manual/autoconf.html#Running-configure-Scripts
http://www.gnu.org/software/autoconf/manual/autoconf.html#Running-configure-Scripts
**Hint on install location**
**Hint on install location**
By default, the package will be installed to /usr/local. However,
By default, the package will be installed to /usr/local. However,
on many platforms, /usr/local/lib is not part of LD_LIBRARY_PATH.
on many platforms, /usr/local/lib is not part of LD_LIBRARY_PATH.
You can add it, but it may be easier to just install to /usr
You can add it, but it may be easier to just install to /usr
instead. To do this, invoke configure as follows:
instead. To do this, invoke configure as follows:
./configure --prefix=/usr
./configure --prefix=/usr
If you already built the package with a different prefix, make sure
If you already built the package with a different prefix, make sure
to run "make clean" before building again.
to run "make clean" before building again.
**Compiling dependent packages**
**Compiling dependent packages**
To compile a package that uses Protocol Buffers, you need to pass
To compile a package that uses Protocol Buffers, you need to pass
various flags to your compiler and linker. As of version 2.2.0,
various flags to your compiler and linker. As of version 2.2.0,
Protocol Buffers integrates with pkg-config to manage this. If you
Protocol Buffers integrates with pkg-config to manage this. If you
have pkg-config installed, then you can invoke it to get a list of
have pkg-config installed, then you can invoke it to get a list of
flags like so:
flags like so:
pkg-config --cflags protobuf # print compiler flags
pkg-config --cflags protobuf # print compiler flags
pkg-config --libs protobuf # print linker flags
pkg-config --libs protobuf # print linker flags
pkg-config --cflags --libs protobuf # print both
pkg-config --cflags --libs protobuf # print both
For example:
For example:
c++ my_program.cc my_proto.pb.cc `pkg-config --cflags --libs protobuf`
c++ my_program.cc my_proto.pb.cc `pkg-config --cflags --libs protobuf`
Note that packages written prior to the 2.2.0 release of Protocol
Note that packages written prior to the 2.2.0 release of Protocol
Buffers may not yet integrate with pkg-config to get flags, and may
Buffers may not yet integrate with pkg-config to get flags, and may
not pass the correct set of flags to correctly link against
not pass the correct set of flags to correctly link against
libprotobuf. If the package in question uses autoconf, you can
libprotobuf. If the package in question uses autoconf, you can
often fix the problem by invoking its configure script like:
often fix the problem by invoking its configure script like:
configure CXXFLAGS="$(pkg-config --cflags protobuf)" \
configure CXXFLAGS="$(pkg-config --cflags protobuf)" \
LIBS="$(pkg-config --libs protobuf)"
LIBS="$(pkg-config --libs protobuf)"
This will force it to use the correct flags.
This will force it to use the correct flags.
If you are writing an autoconf-based package that uses Protocol
If you are writing an autoconf-based package that uses Protocol
Buffers, you should probably use the PKG_CHECK_MODULES macro in your
Buffers, you should probably use the PKG_CHECK_MODULES macro in your
configure script like:
configure script like:
PKG_CHECK_MODULES([protobuf], [protobuf])
PKG_CHECK_MODULES([protobuf], [protobuf])
See the pkg-config man page for more info.
See the pkg-config man page for more info.
If you only want protobuf-lite, substitute "protobuf-lite" in place
If you only want protobuf-lite, substitute "protobuf-lite" in place
of "protobuf" in these examples.
of "protobuf" in these examples.
**Note for Mac users**
**Note for Mac users**
For a Mac system, Unix tools are not available by default. You will first need
For a Mac system, Unix tools are not available by default. You will first need
to install Xcode from the Mac AppStore and then run the following command from
to install Xcode from the Mac AppStore and then run the following command from
a terminal:
a terminal:
$ sudo xcode-select --install
$ sudo xcode-select --install
To install Unix tools, you can install "port" following the instructions at
To install Unix tools, you can install "port" following the instructions at
https://www.macports.org . This will reside in /opt/local/bin/port for most
https://www.macports.org . This will reside in /opt/local/bin/port for most
Mac installations.
Mac installations.
$ sudo /opt/local/bin/port install autoconf automake libtool
$ sudo /opt/local/bin/port install autoconf automake libtool
Then follow the Unix instructions above.
Then follow the Unix instructions above.
**Note for cross-compiling**
**Note for cross-compiling**
The makefiles normally invoke the protoc executable that they just
The makefiles normally invoke the protoc executable that they just
built in order to build tests. When cross-compiling, the protoc
built in order to build tests. When cross-compiling, the protoc
executable may not be executable on the host machine. In this case,
executable may not be executable on the host machine. In this case,
you must build a copy of protoc for the host machine first, then use
you must build a copy of protoc for the host machine first, then use
the --with-protoc option to tell configure to use it instead. For
the --with-protoc option to tell configure to use it instead. For
example:
example:
./configure --with-protoc=protoc
./configure --with-protoc=protoc
This will use the installed protoc (found in your $PATH) instead of
This will use the installed protoc (found in your $PATH) instead of
trying to execute the one built during the build process. You can
trying to execute the one built during the build process. You can
also use an executable that hasn't been installed. For example, if
also use an executable that hasn't been installed. For example, if
you built the protobuf package for your host machine in ../host,
you built the protobuf package for your host machine in ../host,
you might do:
you might do:
./configure --with-protoc=../host/src/protoc
./configure --with-protoc=../host/src/protoc
Either way, you must make sure that the protoc executable you use
Either way, you must make sure that the protoc executable you use
has the same version as the protobuf source code you are trying to
has the same version as the protobuf source code you are trying to
use it with.
use it with.
**Note for Solaris users**
**Note for Solaris users**
Solaris 10 x86 has a bug that will make linking fail, complaining
Solaris 10 x86 has a bug that will make linking fail, complaining
about libstdc++.la being invalid. We have included a work-around
about libstdc++.la being invalid. We have included a work-around
in this package. To use the work-around, run configure as follows:
in this package. To use the work-around, run configure as follows:
./configure LDFLAGS=-L$PWD/src/solaris
./configure LDFLAGS=-L$PWD/src/solaris
See src/solaris/libstdc++.la for more info on this bug.
See src/solaris/libstdc++.la for more info on this bug.
**Note for HP C++ Tru64 users**
**Note for HP C++ Tru64 users**
To compile invoke configure as follows:
To compile invoke configure as follows:
./configure CXXFLAGS="-O -std ansi -ieee -D__USE_STD_IOSTREAM"
./configure CXXFLAGS="-O -std ansi -ieee -D__USE_STD_IOSTREAM"
Also, you will need to use gmake instead of make.
Also, you will need to use gmake instead of make.
**Note for AIX users**
**Note for AIX users**
Compile using the IBM xlC C++ compiler as follows:
Compile using the IBM xlC C++ compiler as follows:
./configure CXX=xlC
./configure CXX=xlC
Also, you will need to use GNU
`make`
(
`gmake`
) instead of AIX
`make`
.
Also, you will need to use GNU
`make`
(
`gmake`
) instead of AIX
`make`
.
C++ Installation - Windows
C++ Installation - Windows
--------------------------
--------------------------
...
@@ -178,7 +184,7 @@ C++ Installation - Windows
...
@@ -178,7 +184,7 @@ C++ Installation - Windows
If you only need the protoc binary, you can download it from the release
If you only need the protoc binary, you can download it from the release
page:
page:
https://github.com/google/protobuf/releases
https://github.com/google/protobuf/releases/latest
In the downloads section, download the zip file protoc-$VERSION-win32.zip.
In the downloads section, download the zip file protoc-$VERSION-win32.zip.
It contains the protoc binary as well as public proto files of protobuf
It contains the protoc binary as well as public proto files of protobuf
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment