Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
B
brpc
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
brpc
Commits
cb998b9e
Commit
cb998b9e
authored
May 14, 2019
by
gejun
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Polish comments in recordio.h
parent
a6886807
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
31 additions
and
20 deletions
+31
-20
recordio.h
src/butil/recordio.h
+31
-20
No files found.
src/butil/recordio.h
View file @
cb998b9e
...
@@ -23,6 +23,11 @@
...
@@ -23,6 +23,11 @@
namespace
butil
{
namespace
butil
{
// One Payload + Zero or multiple Metas.
// Payload and metas are often serialized form of protobuf messages. As a
// correspondence, the implementation is not optimized for very small blobs,
// which should be batched properly before inserting(e.g. using repeated
// field in pb)
class
Record
{
class
Record
{
public
:
public
:
struct
NamedMeta
{
struct
NamedMeta
{
...
@@ -30,35 +35,41 @@ public:
...
@@ -30,35 +35,41 @@ public:
std
::
shared_ptr
<
butil
::
IOBuf
>
data
;
std
::
shared_ptr
<
butil
::
IOBuf
>
data
;
};
};
// Number of meta
// Number of meta
s. Could be 0.
size_t
MetaCount
()
const
{
return
_metas
.
size
();
}
size_t
MetaCount
()
const
{
return
_metas
.
size
();
}
// Get i-th Meta, out-of-range accesses may crash.
// Get i-th Meta, out-of-range accesses may crash.
// This method is mainly for iterating all metas.
const
NamedMeta
&
MetaAt
(
size_t
i
)
const
{
return
_metas
[
i
];
}
const
NamedMeta
&
MetaAt
(
size_t
i
)
const
{
return
_metas
[
i
];
}
// Get meta by
name
.
// Get meta by
|name|. NULL on not found
.
const
butil
::
IOBuf
*
Meta
(
const
char
*
name
)
const
;
const
butil
::
IOBuf
*
Meta
(
const
char
*
name
)
const
;
// Add meta.
// Returns a mutable pointer to the meta with |name|. If the meta does
// Returns a modifiable pointer to the meta with the name.
// not exist, add it first.
// If null_on_found is true and meta with the name is present, NULL is returned.
// If |null_on_found| is true and meta with |name| is present, NULL is
// returned. This is useful for detecting uniqueness of meta names in some
// scenarios.
// NOTE: With the assumption that there won't be many metas, the impl.
// tests presence by scaning all fields, which may perform badly when metas
// are a lot.
butil
::
IOBuf
*
MutableMeta
(
const
char
*
name
,
bool
null_on_found
=
false
);
butil
::
IOBuf
*
MutableMeta
(
const
char
*
name
,
bool
null_on_found
=
false
);
butil
::
IOBuf
*
MutableMeta
(
const
std
::
string
&
name
,
bool
null_on_found
=
false
);
butil
::
IOBuf
*
MutableMeta
(
const
std
::
string
&
name
,
bool
null_on_found
=
false
);
// Remove meta with the name.
// Remove meta with the name.
The impl. may scan all fields.
// Returns true on erased.
// Returns true on erased
, false on absent
.
bool
RemoveMeta
(
const
butil
::
StringPiece
&
name
);
bool
RemoveMeta
(
const
butil
::
StringPiece
&
name
);
// Get the payload.
// Get the payload.
const
butil
::
IOBuf
&
Payload
()
const
{
return
_payload
;
}
const
butil
::
IOBuf
&
Payload
()
const
{
return
_payload
;
}
// Get a m
odifi
able pointer to the payload.
// Get a m
ut
able pointer to the payload.
butil
::
IOBuf
*
MutablePayload
()
{
return
&
_payload
;
}
butil
::
IOBuf
*
MutablePayload
()
{
return
&
_payload
;
}
// Clear payload and remove all meta.
// Clear payload and remove all meta.
void
Clear
();
void
Clear
();
//
Byte size of serialized form
of this record.
//
Serialized size
of this record.
size_t
ByteSize
()
const
;
size_t
ByteSize
()
const
;
private
:
private
:
...
@@ -71,24 +82,24 @@ private:
...
@@ -71,24 +82,24 @@ private:
// RecordReader rd(ireader);
// RecordReader rd(ireader);
// Record rec;
// Record rec;
// while (rd.ReadNext(&rec)) {
// while (rd.ReadNext(&rec)) {
//
HandleRecord(rec);
//
// Handle the rec
// }
// }
// if (rd.last_error() != RecordReader::END_OF_READER) {
// if (rd.last_error() != RecordReader::END_OF_READER) {
// LOG(FATAL) << "Critical error occurred";
// LOG(FATAL) << "Critical error occurred";
// }
// }
class
RecordReader
{
class
RecordReader
{
public
:
public
:
// A special error code to mark end of input data.
static
const
int
END_OF_READER
=
-
1
;
static
const
int
END_OF_READER
=
-
1
;
explicit
RecordReader
(
IReader
*
reader
);
explicit
RecordReader
(
IReader
*
reader
);
// Returns true on success and
`out'
is overwritten by the record.
// Returns true on success and
|out|
is overwritten by the record.
// False otherwise
, check last_error() for
the error which is treated as permanent.
// False otherwise
and last_error() is
the error which is treated as permanent.
bool
ReadNext
(
Record
*
out
);
bool
ReadNext
(
Record
*
out
);
// 0 means no error.
// 0 means no error.
// END_OF_READER means all bytes in the input reader are consumed and
// END_OF_READER means all data in the IReader are successfully consumed.
// turned into records.
int
last_error
()
const
{
return
_last_error
;
}
int
last_error
()
const
{
return
_last_error
;
}
// Total bytes of all read records.
// Total bytes of all read records.
...
@@ -110,12 +121,12 @@ private:
...
@@ -110,12 +121,12 @@ private:
class
RecordWriter
{
class
RecordWriter
{
public
:
public
:
explicit
RecordWriter
(
IWriter
*
writer
);
explicit
RecordWriter
(
IWriter
*
writer
);
// Serialize the record into internal buffer and NOT flush into the IWriter.
int
WriteWithoutFlush
(
const
Record
&
);
// Serialize the record into internal buffer and flush into the IWriter.
// Serialize |record| into internal buffer and NOT flush into the IWriter.
int
Write
(
const
Record
&
);
int
WriteWithoutFlush
(
const
Record
&
record
);
// Serialize |record| into internal buffer and flush into the IWriter.
int
Write
(
const
Record
&
record
);
// Flush internal buffer into the IWriter.
// Flush internal buffer into the IWriter.
// Returns 0 on success, error code otherwise.
// Returns 0 on success, error code otherwise.
...
...
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