README.md 2.53 KB
Newer Older
1 2
This directory contains the C# Protocol Buffers runtime library.

Jon Skeet's avatar
Jon Skeet committed
3 4
Status: Beta - ready for external testing
=========================================
5

6 7 8
Usage
=====

9 10 11
The easiest way how to use C# protobufs is via the `Google.Protobuf`
NuGet package. Just add the NuGet package to your VS project.

12 13
You will also want to install the `Google.Protobuf.Tools` NuGet package, which
contains precompiled version of `protoc.exe` and a copy of well known `.proto`
14 15 16 17
files under the package's `tools` directory.

To generate C# files from your `.proto` files, invoke `protoc` with the 
`--csharp_out` option.
18

19 20 21 22 23 24 25 26 27
Supported platforms
===================

The runtime library is built as a portable class library, supporting:

- .NET 4.5
- Windows 8
- Windows Phone Silverlight 8
- Windows Phone 8.1
Jon Skeet's avatar
Jon Skeet committed
28 29 30 31 32
- .NET Core

You should be able to use Protocol Buffers in Visual Studio 2012 and
all later versions. This includes all code generated by `protoc`,
which only uses features from C# 3 and earlier.
33

34 35 36
Building
========

Jon Skeet's avatar
Jon Skeet committed
37 38 39
Open the `src/Google.Protobuf.sln` solution in Visual Studio 2015 or
later. You should be able to run the NUnit test from Test Explorer
(you might need to install NUnit Visual Studio add-in).
40

Jon Skeet's avatar
Jon Skeet committed
41 42 43 44 45 46
Although *users* of this project are only expected to have Visual
Studio 2012 or later, *developers* of the library are required to
have Visual Studio 2015 or later, as the library uses C# 6 features
in its implementation. These features have no impact when using the
compiled code - they're only relevant when building the
`Google.Protobuf` assembly.
47

48
History of C# protobufs
49
=======================
50 51 52 53

This subtree was originally imported from https://github.com/jskeet/protobuf-csharp-port
and represents the latest development version of C# protobufs, that will now be developed
and maintained by Google. All the development will be done in open, under this repository
54
(https://github.com/google/protobuf).
Jon Skeet's avatar
Jon Skeet committed
55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70

The previous project differs from this project in a number of ways:

- The old code only supported proto2; the new code only supports
proto3 (so no unknown fields, no required/optional distinction, no
extensions)
- The old code was based on immutable message types and builders for
them
- The old code did not support maps or `oneof`
- The old code had its own JSON representation, whereas the new code
uses the standard protobuf JSON representation
- The old code had no notion of the "well-known types" which have
special support in the new code
- The old project supported some older platforms (such as older
versions of Silverlight) which are not currently supported in the
new project