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
38d453d3
Commit
38d453d3
authored
Aug 14, 2008
by
Jon Skeet
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Beginning to fix the TODOs
parent
15041fa0
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
189 additions
and
205 deletions
+189
-205
AbstractBuilder.cs
csharp/ProtocolBuffers/AbstractBuilder.cs
+1
-1
DynamicMessage.cs
csharp/ProtocolBuffers/DynamicMessage.cs
+1
-1
ExtendableBuilder.cs
csharp/ProtocolBuffers/ExtendableBuilder.cs
+1
-1
FieldSet.cs
csharp/ProtocolBuffers/FieldSet.cs
+0
-201
UnknownFieldSet.cs
csharp/ProtocolBuffers/UnknownFieldSet.cs
+186
-0
csharp_primitive_field.cc
...google/protobuf/compiler/csharp/csharp_primitive_field.cc
+0
-1
No files found.
csharp/ProtocolBuffers/AbstractBuilder.cs
View file @
38d453d3
...
...
@@ -155,7 +155,7 @@ namespace Google.ProtocolBuffers {
public
virtual
TBuilder
MergeFrom
(
CodedInputStream
input
,
ExtensionRegistry
extensionRegistry
)
{
UnknownFieldSet
.
Builder
unknownFields
=
UnknownFieldSet
.
CreateBuilder
(
UnknownFields
);
FieldSet
.
MergeFrom
(
input
,
unknownFields
,
extensionRegistry
,
this
);
unknownFields
.
MergeFrom
(
input
,
extensionRegistry
,
this
);
UnknownFields
=
unknownFields
.
Build
();
return
ThisBuilder
;
}
...
...
csharp/ProtocolBuffers/DynamicMessage.cs
View file @
38d453d3
...
...
@@ -318,7 +318,7 @@ namespace Google.ProtocolBuffers {
public
override
Builder
MergeFrom
(
CodedInputStream
input
,
ExtensionRegistry
extensionRegistry
)
{
UnknownFieldSet
.
Builder
unknownFieldsBuilder
=
UnknownFieldSet
.
CreateBuilder
(
unknownFields
);
FieldSet
.
MergeFrom
(
input
,
unknownFieldsBuilder
,
extensionRegistry
,
this
);
unknownFieldsBuilder
.
MergeFrom
(
input
,
extensionRegistry
,
this
);
unknownFields
=
unknownFieldsBuilder
.
Build
();
return
this
;
}
...
...
csharp/ProtocolBuffers/ExtendableBuilder.cs
View file @
38d453d3
...
...
@@ -97,7 +97,7 @@ namespace Google.ProtocolBuffers {
/// <returns>true unless the tag is an end-group tag</returns>
protected
override
bool
ParseUnknownField
(
CodedInputStream
input
,
UnknownFieldSet
.
Builder
unknownFields
,
ExtensionRegistry
extensionRegistry
,
uint
tag
)
{
return
FieldSet
.
MergeFieldFrom
(
input
,
unknownFields
,
extensionRegistry
,
this
,
tag
);
return
unknownFields
.
MergeFieldFrom
(
input
,
extensionRegistry
,
this
,
tag
);
}
// ---------------------------------------------------------------
...
...
csharp/ProtocolBuffers/FieldSet.cs
View file @
38d453d3
...
...
@@ -105,207 +105,6 @@ namespace Google.ProtocolBuffers {
return
fields
.
ContainsKey
(
field
);
}
// TODO(jonskeet): Should this be in UnknownFieldSet.Builder really? Or CodedInputStream?
internal
static
void
MergeFrom
(
CodedInputStream
input
,
UnknownFieldSet
.
Builder
unknownFields
,
ExtensionRegistry
extensionRegistry
,
IBuilder
builder
)
{
while
(
true
)
{
uint
tag
=
input
.
ReadTag
();
if
(
tag
==
0
)
{
break
;
}
if
(!
MergeFieldFrom
(
input
,
unknownFields
,
extensionRegistry
,
builder
,
tag
))
{
// end group tag
break
;
}
}
}
// TODO(jonskeet): Should this be in UnknownFieldSet.Builder really? Or CodedInputStream?
/// <summary>
/// Like <see cref="MergeFrom(CodedInputStream, UnknownFieldSet.Builder, ExtensionRegistry, IBuilder)" />
/// but parses a single field.
/// </summary>
/// <param name="input">The input to read the field from</param>
/// <param name="unknownFields">The set of unknown fields to add the newly-read field to, if it's not a known field</param>
/// <param name="extensionRegistry">Registry to use when an extension field is encountered</param>
/// <param name="builder">Builder to merge field into, if it's a known field</param>
/// <param name="tag">The tag, which should already have been read from the input</param>
/// <returns>true unless the tag is an end-group tag</returns>
internal
static
bool
MergeFieldFrom
(
CodedInputStream
input
,
UnknownFieldSet
.
Builder
unknownFields
,
ExtensionRegistry
extensionRegistry
,
IBuilder
builder
,
uint
tag
)
{
MessageDescriptor
type
=
builder
.
DescriptorForType
;
if
(
type
.
Options
.
MessageSetWireFormat
&&
tag
==
WireFormat
.
MessageSetTag
.
ItemStart
)
{
MergeMessageSetExtensionFromCodedStream
(
input
,
unknownFields
,
extensionRegistry
,
builder
);
return
true
;
}
WireFormat
.
WireType
wireType
=
WireFormat
.
GetTagWireType
(
tag
);
int
fieldNumber
=
WireFormat
.
GetTagFieldNumber
(
tag
);
FieldDescriptor
field
;
IMessage
defaultFieldInstance
=
null
;
if
(
type
.
IsExtensionNumber
(
fieldNumber
))
{
ExtensionInfo
extension
=
extensionRegistry
[
type
,
fieldNumber
];
if
(
extension
==
null
)
{
field
=
null
;
}
else
{
field
=
extension
.
Descriptor
;
defaultFieldInstance
=
extension
.
DefaultInstance
;
}
}
else
{
field
=
type
.
FindFieldByNumber
(
fieldNumber
);
}
// Unknown field or wrong wire type. Skip.
if
(
field
==
null
||
wireType
!=
WireFormat
.
FieldTypeToWireFormatMap
[
field
.
FieldType
])
{
return
unknownFields
.
MergeFieldFrom
(
tag
,
input
);
}
object
value
;
switch
(
field
.
FieldType
)
{
case
FieldType
.
Group
:
case
FieldType
.
Message
:
{
IBuilder
subBuilder
;
if
(
defaultFieldInstance
!=
null
)
{
subBuilder
=
defaultFieldInstance
.
WeakCreateBuilderForType
();
}
else
{
subBuilder
=
builder
.
CreateBuilderForField
(
field
);
}
if
(!
field
.
IsRepeated
)
{
subBuilder
.
WeakMergeFrom
((
IMessage
)
builder
[
field
]);
}
if
(
field
.
FieldType
==
FieldType
.
Group
)
{
input
.
ReadGroup
(
field
.
FieldNumber
,
subBuilder
,
extensionRegistry
);
}
else
{
input
.
ReadMessage
(
subBuilder
,
extensionRegistry
);
}
value
=
subBuilder
.
WeakBuild
();
break
;
}
case
FieldType
.
Enum
:
{
int
rawValue
=
input
.
ReadEnum
();
value
=
field
.
EnumType
.
FindValueByNumber
(
rawValue
);
// If the number isn't recognized as a valid value for this enum,
// drop it.
if
(
value
==
null
)
{
unknownFields
.
MergeVarintField
(
fieldNumber
,
(
ulong
)
rawValue
);
return
true
;
}
break
;
}
default
:
value
=
input
.
ReadPrimitiveField
(
field
.
FieldType
);
break
;
}
if
(
field
.
IsRepeated
)
{
builder
.
WeakAddRepeatedField
(
field
,
value
);
}
else
{
builder
[
field
]
=
value
;
}
return
true
;
}
// TODO(jonskeet): Should this be in UnknownFieldSet.Builder really? Or CodedInputStream?
/// <summary>
/// Called by MergeFieldFrom to parse a MessageSet extension.
/// </summary>
private
static
void
MergeMessageSetExtensionFromCodedStream
(
CodedInputStream
input
,
UnknownFieldSet
.
Builder
unknownFields
,
ExtensionRegistry
extensionRegistry
,
IBuilder
builder
)
{
MessageDescriptor
type
=
builder
.
DescriptorForType
;
// The wire format for MessageSet is:
// message MessageSet {
// repeated group Item = 1 {
// required int32 typeId = 2;
// required bytes message = 3;
// }
// }
// "typeId" is the extension's field number. The extension can only be
// a message type, where "message" contains the encoded bytes of that
// message.
//
// In practice, we will probably never see a MessageSet item in which
// the message appears before the type ID, or where either field does not
// appear exactly once. However, in theory such cases are valid, so we
// should be prepared to accept them.
int
typeId
=
0
;
ByteString
rawBytes
=
null
;
// If we encounter "message" before "typeId"
IBuilder
subBuilder
=
null
;
FieldDescriptor
field
=
null
;
while
(
true
)
{
uint
tag
=
input
.
ReadTag
();
if
(
tag
==
0
)
{
break
;
}
if
(
tag
==
WireFormat
.
MessageSetTag
.
TypeID
)
{
typeId
=
input
.
ReadInt32
();
// Zero is not a valid type ID.
if
(
typeId
!=
0
)
{
ExtensionInfo
extension
=
extensionRegistry
[
type
,
typeId
];
if
(
extension
!=
null
)
{
field
=
extension
.
Descriptor
;
subBuilder
=
extension
.
DefaultInstance
.
WeakCreateBuilderForType
();
IMessage
originalMessage
=
(
IMessage
)
builder
[
field
];
if
(
originalMessage
!=
null
)
{
subBuilder
.
WeakMergeFrom
(
originalMessage
);
}
if
(
rawBytes
!=
null
)
{
// We already encountered the message. Parse it now.
// TODO(jonskeet): Check this is okay. It's subtly different from the Java, as it doesn't create an input stream from rawBytes.
// In fact, why don't we just call MergeFrom(rawBytes)? And what about the extension registry?
subBuilder
.
WeakMergeFrom
(
rawBytes
.
CreateCodedInput
());
rawBytes
=
null
;
}
}
else
{
// Unknown extension number. If we already saw data, put it
// in rawBytes.
if
(
rawBytes
!=
null
)
{
unknownFields
.
MergeField
(
typeId
,
UnknownField
.
CreateBuilder
()
.
AddLengthDelimited
(
rawBytes
)
.
Build
());
rawBytes
=
null
;
}
}
}
}
else
if
(
tag
==
WireFormat
.
MessageSetTag
.
Message
)
{
if
(
typeId
==
0
)
{
// We haven't seen a type ID yet, so we have to store the raw bytes for now.
rawBytes
=
input
.
ReadBytes
();
}
else
if
(
subBuilder
==
null
)
{
// We don't know how to parse this. Ignore it.
unknownFields
.
MergeField
(
typeId
,
UnknownField
.
CreateBuilder
()
.
AddLengthDelimited
(
input
.
ReadBytes
())
.
Build
());
}
else
{
// We already know the type, so we can parse directly from the input
// with no copying. Hooray!
input
.
ReadMessage
(
subBuilder
,
extensionRegistry
);
}
}
else
{
// Unknown tag. Skip it.
if
(!
input
.
SkipField
(
tag
))
{
break
;
// end of group
}
}
}
input
.
CheckLastTagWas
(
WireFormat
.
MessageSetTag
.
ItemEnd
);
if
(
subBuilder
!=
null
)
{
builder
[
field
]
=
subBuilder
.
WeakBuild
();
}
}
/// <summary>
/// Clears all fields.
/// </summary>
...
...
csharp/ProtocolBuffers/UnknownFieldSet.cs
View file @
38d453d3
...
...
@@ -17,6 +17,7 @@ using System;
using
System.Collections.Generic
;
using
System.IO
;
using
Google.ProtocolBuffers.Collections
;
using
Google.ProtocolBuffers.Descriptors
;
namespace
Google.ProtocolBuffers
{
/// <summary>
...
...
@@ -430,6 +431,191 @@ namespace Google.ProtocolBuffers {
return
this
;
}
internal
void
MergeFrom
(
CodedInputStream
input
,
ExtensionRegistry
extensionRegistry
,
IBuilder
builder
)
{
while
(
true
)
{
uint
tag
=
input
.
ReadTag
();
if
(
tag
==
0
)
{
break
;
}
if
(!
MergeFieldFrom
(
input
,
extensionRegistry
,
builder
,
tag
))
{
// end group tag
break
;
}
}
}
/// <summary>
/// Like <see cref="MergeFrom(CodedInputStream, ExtensionRegistry, IBuilder)" />
/// but parses a single field.
/// </summary>
/// <param name="input">The input to read the field from</param>
/// <param name="extensionRegistry">Registry to use when an extension field is encountered</param>
/// <param name="builder">Builder to merge field into, if it's a known field</param>
/// <param name="tag">The tag, which should already have been read from the input</param>
/// <returns>true unless the tag is an end-group tag</returns>
internal
bool
MergeFieldFrom
(
CodedInputStream
input
,
ExtensionRegistry
extensionRegistry
,
IBuilder
builder
,
uint
tag
)
{
MessageDescriptor
type
=
builder
.
DescriptorForType
;
if
(
type
.
Options
.
MessageSetWireFormat
&&
tag
==
WireFormat
.
MessageSetTag
.
ItemStart
)
{
MergeMessageSetExtensionFromCodedStream
(
input
,
extensionRegistry
,
builder
);
return
true
;
}
WireFormat
.
WireType
wireType
=
WireFormat
.
GetTagWireType
(
tag
);
int
fieldNumber
=
WireFormat
.
GetTagFieldNumber
(
tag
);
FieldDescriptor
field
;
IMessage
defaultFieldInstance
=
null
;
if
(
type
.
IsExtensionNumber
(
fieldNumber
))
{
ExtensionInfo
extension
=
extensionRegistry
[
type
,
fieldNumber
];
if
(
extension
==
null
)
{
field
=
null
;
}
else
{
field
=
extension
.
Descriptor
;
defaultFieldInstance
=
extension
.
DefaultInstance
;
}
}
else
{
field
=
type
.
FindFieldByNumber
(
fieldNumber
);
}
// Unknown field or wrong wire type. Skip.
if
(
field
==
null
||
wireType
!=
WireFormat
.
FieldTypeToWireFormatMap
[
field
.
FieldType
])
{
return
MergeFieldFrom
(
tag
,
input
);
}
object
value
;
switch
(
field
.
FieldType
)
{
case
FieldType
.
Group
:
case
FieldType
.
Message
:
{
IBuilder
subBuilder
;
if
(
defaultFieldInstance
!=
null
)
{
subBuilder
=
defaultFieldInstance
.
WeakCreateBuilderForType
();
}
else
{
subBuilder
=
builder
.
CreateBuilderForField
(
field
);
}
if
(!
field
.
IsRepeated
)
{
subBuilder
.
WeakMergeFrom
((
IMessage
)
builder
[
field
]);
}
if
(
field
.
FieldType
==
FieldType
.
Group
)
{
input
.
ReadGroup
(
field
.
FieldNumber
,
subBuilder
,
extensionRegistry
);
}
else
{
input
.
ReadMessage
(
subBuilder
,
extensionRegistry
);
}
value
=
subBuilder
.
WeakBuild
();
break
;
}
case
FieldType
.
Enum
:
{
int
rawValue
=
input
.
ReadEnum
();
value
=
field
.
EnumType
.
FindValueByNumber
(
rawValue
);
// If the number isn't recognized as a valid value for this enum,
// drop it.
if
(
value
==
null
)
{
MergeVarintField
(
fieldNumber
,
(
ulong
)
rawValue
);
return
true
;
}
break
;
}
default
:
value
=
input
.
ReadPrimitiveField
(
field
.
FieldType
);
break
;
}
if
(
field
.
IsRepeated
)
{
builder
.
WeakAddRepeatedField
(
field
,
value
);
}
else
{
builder
[
field
]
=
value
;
}
return
true
;
}
/// <summary>
/// Called by MergeFieldFrom to parse a MessageSet extension.
/// </summary>
private
void
MergeMessageSetExtensionFromCodedStream
(
CodedInputStream
input
,
ExtensionRegistry
extensionRegistry
,
IBuilder
builder
)
{
MessageDescriptor
type
=
builder
.
DescriptorForType
;
// The wire format for MessageSet is:
// message MessageSet {
// repeated group Item = 1 {
// required int32 typeId = 2;
// required bytes message = 3;
// }
// }
// "typeId" is the extension's field number. The extension can only be
// a message type, where "message" contains the encoded bytes of that
// message.
//
// In practice, we will probably never see a MessageSet item in which
// the message appears before the type ID, or where either field does not
// appear exactly once. However, in theory such cases are valid, so we
// should be prepared to accept them.
int
typeId
=
0
;
ByteString
rawBytes
=
null
;
// If we encounter "message" before "typeId"
IBuilder
subBuilder
=
null
;
FieldDescriptor
field
=
null
;
while
(
true
)
{
uint
tag
=
input
.
ReadTag
();
if
(
tag
==
0
)
{
break
;
}
if
(
tag
==
WireFormat
.
MessageSetTag
.
TypeID
)
{
typeId
=
input
.
ReadInt32
();
// Zero is not a valid type ID.
if
(
typeId
!=
0
)
{
ExtensionInfo
extension
=
extensionRegistry
[
type
,
typeId
];
if
(
extension
!=
null
)
{
field
=
extension
.
Descriptor
;
subBuilder
=
extension
.
DefaultInstance
.
WeakCreateBuilderForType
();
IMessage
originalMessage
=
(
IMessage
)
builder
[
field
];
if
(
originalMessage
!=
null
)
{
subBuilder
.
WeakMergeFrom
(
originalMessage
);
}
if
(
rawBytes
!=
null
)
{
// We already encountered the message. Parse it now.
// TODO(jonskeet): Check this is okay. It's subtly different from the Java, as it doesn't create an input stream from rawBytes.
// In fact, why don't we just call MergeFrom(rawBytes)? And what about the extension registry?
subBuilder
.
WeakMergeFrom
(
rawBytes
.
CreateCodedInput
());
rawBytes
=
null
;
}
}
else
{
// Unknown extension number. If we already saw data, put it
// in rawBytes.
if
(
rawBytes
!=
null
)
{
MergeField
(
typeId
,
UnknownField
.
CreateBuilder
().
AddLengthDelimited
(
rawBytes
).
Build
());
rawBytes
=
null
;
}
}
}
}
else
if
(
tag
==
WireFormat
.
MessageSetTag
.
Message
)
{
if
(
typeId
==
0
)
{
// We haven't seen a type ID yet, so we have to store the raw bytes for now.
rawBytes
=
input
.
ReadBytes
();
}
else
if
(
subBuilder
==
null
)
{
// We don't know how to parse this. Ignore it.
MergeField
(
typeId
,
UnknownField
.
CreateBuilder
().
AddLengthDelimited
(
input
.
ReadBytes
()).
Build
());
}
else
{
// We already know the type, so we can parse directly from the input
// with no copying. Hooray!
input
.
ReadMessage
(
subBuilder
,
extensionRegistry
);
}
}
else
{
// Unknown tag. Skip it.
if
(!
input
.
SkipField
(
tag
))
{
break
;
// end of group
}
}
}
input
.
CheckLastTagWas
(
WireFormat
.
MessageSetTag
.
ItemEnd
);
if
(
subBuilder
!=
null
)
{
builder
[
field
]
=
subBuilder
.
WeakBuild
();
}
}
}
}
}
src/google/protobuf/compiler/csharp/csharp_primitive_field.cc
View file @
38d453d3
...
...
@@ -113,7 +113,6 @@ string DefaultValue(const FieldDescriptor* field) {
// Escaping strings correctly for Java and generating efficient
// initializers for ByteStrings are both tricky. We can sidestep the
// whole problem by just grabbing the default value from the descriptor.
// TODO(jonskeet): FIXME!
return
strings
::
Substitute
(
"(($0) $1.Descriptor.Fields[$2].DefaultValue)"
,
isBytes
?
"pb::ByteString"
:
"string"
,
...
...
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