Download the PHP package mariopenterman/protobuf-plugin without Composer
On this page you can find all versions of the php package mariopenterman/protobuf-plugin. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download mariopenterman/protobuf-plugin
More information about mariopenterman/protobuf-plugin
Files in mariopenterman/protobuf-plugin
Package protobuf-plugin
Short Description PHP Code generator plugin from Google's Protocol Buffers
License MIT
Homepage https://github.com/mariopenterman/protobuf-plugin
Informations about the package protobuf-plugin
Protobuf for PHP
Protobuf for PHP is an implementation of Google's Protocol Buffers for the PHP
language, supporting its binary data serialization and including a protoc
plugin to generate PHP classes from files.
Installation
If you wish to compile definitions to PHP, you will need to install Google's Protocol Buffers from your favorite package manager or from source. This plugin currently supports protobuf 2.3.0. or later.
Note: Google's Protocol Buffers and is not a runtime requirement for protobuf-php/protobuf, It is only necessary if you wish to compile your definitions to PHP using protobuf-php/protobuf-plugin.
Installing Google's Protocol Buffers
-
OSX Install
- Ubuntu
Make sure you have available in the user's path:
Note: For more information on how to install/compile Google's Protocol Buffers see : https://github.com/google/protobuf
Composer install
To install the PHP plugin run the following composer
commands:
Defining Your Protocol Format
To create your address book application, you'll need to start with a file. The definitions in a file are simple: you add a message for each data structure you want to serialize, then specify a name and a type for each field in the message. Here is the file that defines your messages, .
As you can see, the syntax is similar to C++ or Java. Let's go through each part of the file and see what it does. The file starts with a package declaration, which helps to prevent naming conflicts between different projects. In PHP, the package name is used as the PHP namespace unless you have explicitly specified a , as we have here. Even if you do provide a , you should still define a normal package as well to avoid name collisions in the Protocol Buffers name space as well as in non PHP languages.
You'll find a complete guide to writing files – including all the possible field types – in the Protocol Buffer Language Guide. Don't go looking for facilities similar to class inheritance, though – protocol buffers don't do that.
Compiling Your Protocol Buffers
Now that you have a , the next thing you need to do is generate the classes you'll need to read and write (and hence and ) messages. To do this, you need to run the protocol buffer plugin on your .
In this case:
This generates the following PHP classes in your specified destination directory
Note: For more information on how to use the generated code see : protobuf-php/protobuf
All versions of protobuf-plugin with dependencies
protobuf-php/protobuf Version >=0.1
protobuf-php/google-protobuf-proto Version >=0.1
zendframework/zend-code Version ^2.6
psr/log Version ^1.0
symfony/console Version ^5.0
symfony/process Version ^5.0
doctrine/inflector Version ^1.0