Skip to content

Commit

Permalink
db-ctl-base: do not expose get_table() API
Browse files Browse the repository at this point in the history
Both get_table() and set_cloum() APIs are mostly used within db-ctl-base
library. This patch makes both private to the library.

Add a new ctl_set_colum() API for library client.

The changes are cleanups. No functional changes.

Signed-off-by: Andy Zhou <[email protected]>
Acked-by: Alex Wang <[email protected]>
  • Loading branch information
azhou-nicira committed Jul 13, 2015
1 parent 07d2723 commit 15ffc20
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 8 deletions.
15 changes: 13 additions & 2 deletions lib/db-ctl-base.c
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,10 @@ struct ovsdb_idl *the_idl;
struct ovsdb_idl_txn *the_idl_txn;

static struct shash all_commands = SHASH_INITIALIZER(&all_commands);
static const struct ctl_table_class *get_table(const char *table_name);
static void set_column(const struct ctl_table_class *,
const struct ovsdb_idl_row *, const char *,
struct ovsdb_symbol_table *);


static struct option *
Expand Down Expand Up @@ -1990,7 +1994,7 @@ ctl_context_done(struct ctl_context *ctx,

/* Finds and returns the "struct ctl_table_class *" with 'table_name' by
* searching the 'tables'. */
const struct ctl_table_class *
static const struct ctl_table_class *
get_table(const char *table_name)
{
const struct ctl_table_class *table;
Expand Down Expand Up @@ -2018,7 +2022,7 @@ get_table(const char *table_name)
}

/* Sets the column of 'row' in 'table'. */
void
static void
set_column(const struct ctl_table_class *table,
const struct ovsdb_idl_row *row, const char *arg,
struct ovsdb_symbol_table *symtab)
Expand Down Expand Up @@ -2070,3 +2074,10 @@ set_column(const struct ctl_table_class *table,
free(key_string);
free(value_string);
}

void ctl_set_column(const char *table_name,
const struct ovsdb_idl_row *row, const char *arg,
struct ovsdb_symbol_table *symtab)
{
set_column(get_table(table_name), row, arg, symtab);
}
7 changes: 3 additions & 4 deletions lib/db-ctl-base.h
Original file line number Diff line number Diff line change
Expand Up @@ -250,9 +250,8 @@ struct ctl_table_class {
* entry. */
extern const struct ctl_table_class tables[];

const struct ctl_table_class *get_table(const char *table_name);
void set_column(const struct ctl_table_class *,
const struct ovsdb_idl_row *, const char *arg,
struct ovsdb_symbol_table *);
void ctl_set_column(const char *table_name,
const struct ovsdb_idl_row *, const char *arg,
struct ovsdb_symbol_table *);

#endif /* db-ctl-base.h */
4 changes: 2 additions & 2 deletions utilities/ovs-vsctl.c
Original file line number Diff line number Diff line change
Expand Up @@ -1556,8 +1556,8 @@ add_port(struct ctl_context *ctx,
}

for (i = 0; i < n_settings; i++) {
set_column(get_table("Port"), &port->header_, settings[i],
ctx->symtab);
ctl_set_column("Port", &port->header_, settings[i],
ctx->symtab);
}

bridge_insert_port((bridge->parent ? bridge->parent->br_cfg
Expand Down

0 comments on commit 15ffc20

Please sign in to comment.