projects
/
openvswitch
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
netdev-linux: Fix strict aliasing warnings.
[openvswitch]
/
ovsdb
/
column.c
diff --git
a/ovsdb/column.c
b/ovsdb/column.c
index 0a1f6e4d9fbd612cfc4e0ae1c92d1653d1441f86..a22e1a237021dba1f4e242ff41a3e191f0d5869d 100644
(file)
--- a/
ovsdb/column.c
+++ b/
ovsdb/column.c
@@
-27,15
+27,15
@@
#include "util.h"
struct ovsdb_column *
#include "util.h"
struct ovsdb_column *
-ovsdb_column_create(const char *name,
const char *comment,
+ovsdb_column_create(const char *name,
bool mutable, bool persistent,
const struct ovsdb_type *type)
{
bool mutable, bool persistent,
const struct ovsdb_type *type)
{
+ /* Doesn't set the new column's 'index': the caller must do that. */
struct ovsdb_column *column;
column = xzalloc(sizeof *column);
column->name = xstrdup(name);
struct ovsdb_column *column;
column = xzalloc(sizeof *column);
column->name = xstrdup(name);
- column->comment = comment ? xstrdup(comment) : NULL;
column->mutable = mutable;
column->persistent = persistent;
ovsdb_type_clone(&column->type, type);
column->mutable = mutable;
column->persistent = persistent;
ovsdb_type_clone(&column->type, type);
@@
-43,12
+43,20
@@
ovsdb_column_create(const char *name, const char *comment,
return column;
}
return column;
}
+struct ovsdb_column *
+ovsdb_column_clone(const struct ovsdb_column *old)
+{
+ /* Doesn't copy the column's 'index': the caller must do that. */
+ return ovsdb_column_create(old->name,
+ old->mutable, old->persistent,
+ &old->type);
+}
+
void
ovsdb_column_destroy(struct ovsdb_column *column)
{
ovsdb_type_destroy(&column->type);
free(column->name);
void
ovsdb_column_destroy(struct ovsdb_column *column)
{
ovsdb_type_destroy(&column->type);
free(column->name);
- free(column->comment);
free(column);
}
free(column);
}
@@
-56,7
+64,7
@@
struct ovsdb_error *
ovsdb_column_from_json(const struct json *json, const char *name,
struct ovsdb_column **columnp)
{
ovsdb_column_from_json(const struct json *json, const char *name,
struct ovsdb_column **columnp)
{
- const struct json *
comment, *
mutable, *ephemeral, *type_json;
+ const struct json *mutable, *ephemeral, *type_json;
struct ovsdb_error *error;
struct ovsdb_type type;
struct ovsdb_parser parser;
struct ovsdb_error *error;
struct ovsdb_type type;
struct ovsdb_parser parser;
@@
-65,7
+73,6
@@
ovsdb_column_from_json(const struct json *json, const char *name,
*columnp = NULL;
ovsdb_parser_init(&parser, json, "schema for column %s", name);
*columnp = NULL;
ovsdb_parser_init(&parser, json, "schema for column %s", name);
- comment = ovsdb_parser_member(&parser, "comment", OP_STRING | OP_OPTIONAL);
mutable = ovsdb_parser_member(&parser, "mutable",
OP_TRUE | OP_FALSE | OP_OPTIONAL);
ephemeral = ovsdb_parser_member(&parser, "ephemeral",
mutable = ovsdb_parser_member(&parser, "mutable",
OP_TRUE | OP_FALSE | OP_OPTIONAL);
ephemeral = ovsdb_parser_member(&parser, "ephemeral",
@@
-83,7
+90,6
@@
ovsdb_column_from_json(const struct json *json, const char *name,
persistent = ephemeral ? !json_boolean(ephemeral) : true;
*columnp = ovsdb_column_create(name,
persistent = ephemeral ? !json_boolean(ephemeral) : true;
*columnp = ovsdb_column_create(name,
- comment ? json_string(comment) : NULL,
mutable ? json_boolean(mutable) : true,
persistent, &type);
mutable ? json_boolean(mutable) : true,
persistent, &type);
@@
-96,9
+102,6
@@
struct json *
ovsdb_column_to_json(const struct ovsdb_column *column)
{
struct json *json = json_object_create();
ovsdb_column_to_json(const struct ovsdb_column *column)
{
struct json *json = json_object_create();
- if (column->comment) {
- json_object_put_string(json, "comment", column->comment);
- }
if (!column->mutable) {
json_object_put(json, "mutable", json_boolean_create(false));
}
if (!column->mutable) {
json_object_put(json, "mutable", json_boolean_create(false));
}