X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fovsdb-types.h;h=efd83a7916971b5aa5282d727b50b49536367fbb;hb=cfc50ae514f805dcd9c14589f21158185424daf6;hp=b9b3d5a02338ceb5fb222948a6c9f48b8198a9b8;hpb=a4af00400a835eb87569ba40e21874c05e872c0f;p=sliver-openvswitch.git diff --git a/lib/ovsdb-types.h b/lib/ovsdb-types.h index b9b3d5a02..efd83a791 100644 --- a/lib/ovsdb-types.h +++ b/lib/ovsdb-types.h @@ -1,4 +1,4 @@ -/* Copyright (c) 2009, 2010 Nicira Networks +/* Copyright (c) 2009, 2010, 2011 Nicira, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -16,6 +16,7 @@ #ifndef OVSDB_TYPES_H #define OVSDB_TYPES_H 1 +#include #include #include #include "compiler.h" @@ -35,13 +36,83 @@ enum ovsdb_atomic_type { }; static inline bool ovsdb_atomic_type_is_valid(enum ovsdb_atomic_type); -static inline bool ovsdb_atomic_type_is_valid_key(enum ovsdb_atomic_type); bool ovsdb_atomic_type_from_string(const char *, enum ovsdb_atomic_type *); struct ovsdb_error *ovsdb_atomic_type_from_json(enum ovsdb_atomic_type *, const struct json *); const char *ovsdb_atomic_type_to_string(enum ovsdb_atomic_type); struct json *ovsdb_atomic_type_to_json(enum ovsdb_atomic_type); +/* An atomic type plus optional constraints. */ + +enum ovsdb_ref_type { + OVSDB_REF_STRONG, /* Target must exist. */ + OVSDB_REF_WEAK /* Delete reference if target disappears. */ +}; + +struct ovsdb_base_type { + enum ovsdb_atomic_type type; + + /* If nonnull, a datum with keys of type 'type' that expresses all the + * valid values for this base_type. */ + struct ovsdb_datum *enum_; + + union { + struct ovsdb_integer_constraints { + int64_t min; /* minInteger or INT64_MIN. */ + int64_t max; /* maxInteger or INT64_MAX. */ + } integer; + + struct ovsdb_real_constraints { + double min; /* minReal or -DBL_MAX. */ + double max; /* minReal or DBL_MAX. */ + } real; + + /* No constraints for Boolean types. */ + + struct ovsdb_string_constraints { + unsigned int minLen; /* minLength or 0. */ + unsigned int maxLen; /* maxLength or UINT_MAX. */ + } string; + + struct ovsdb_uuid_constraints { + char *refTableName; /* Name of referenced table, or NULL. */ + struct ovsdb_table *refTable; /* Referenced table, if available. */ + enum ovsdb_ref_type refType; /* Reference type. */ + } uuid; + } u; +}; + +#define OVSDB_BASE_VOID_INIT { .type = OVSDB_TYPE_VOID } +#define OVSDB_BASE_INTEGER_INIT { .type = OVSDB_TYPE_INTEGER, \ + .u.integer = { INT64_MIN, INT64_MAX } } +#define OVSDB_BASE_REAL_INIT { .type = OVSDB_TYPE_REAL, \ + .u.real = { -DBL_MAX, DBL_MAX } } +#define OVSDB_BASE_BOOLEAN_INIT { .type = OVSDB_TYPE_BOOLEAN } +#define OVSDB_BASE_STRING_INIT { .type = OVSDB_TYPE_STRING, \ + .u.string = { 0, UINT_MAX } } +#define OVSDB_BASE_UUID_INIT { .type = OVSDB_TYPE_UUID, \ + .u.uuid = { NULL, NULL, 0 } } + +void ovsdb_base_type_init(struct ovsdb_base_type *, enum ovsdb_atomic_type); +void ovsdb_base_type_clone(struct ovsdb_base_type *, + const struct ovsdb_base_type *); +void ovsdb_base_type_destroy(struct ovsdb_base_type *); + +bool ovsdb_base_type_is_valid(const struct ovsdb_base_type *); +bool ovsdb_base_type_has_constraints(const struct ovsdb_base_type *); +void ovsdb_base_type_clear_constraints(struct ovsdb_base_type *); +const struct ovsdb_type *ovsdb_base_type_get_enum_type(enum ovsdb_atomic_type); + +struct ovsdb_error *ovsdb_base_type_from_json(struct ovsdb_base_type *, + const struct json *) + WARN_UNUSED_RESULT; +struct json *ovsdb_base_type_to_json(const struct ovsdb_base_type *); + +static inline bool ovsdb_base_type_is_ref(const struct ovsdb_base_type *); +static inline bool ovsdb_base_type_is_strong_ref( + const struct ovsdb_base_type *); +static inline bool ovsdb_base_type_is_weak_ref(const struct ovsdb_base_type *); + /* An OVSDB type. * * Several rules constrain the valid types. See ovsdb_type_is_valid() (in @@ -60,14 +131,13 @@ struct json *ovsdb_atomic_type_to_json(enum ovsdb_atomic_type); * can also be considered an optional pair of 'key_type' and 'value_type'. */ struct ovsdb_type { - enum ovsdb_atomic_type key_type; - enum ovsdb_atomic_type value_type; + struct ovsdb_base_type key; + struct ovsdb_base_type value; unsigned int n_min; unsigned int n_max; /* UINT_MAX stands in for "unlimited". */ }; -#define OVSDB_TYPE_SCALAR_INITIALIZER(KEY_TYPE) \ - { KEY_TYPE, OVSDB_TYPE_VOID, 1, 1 } +#define OVSDB_TYPE_SCALAR_INITIALIZER(KEY) { KEY, OVSDB_BASE_VOID_INIT, 1, 1 } extern const struct ovsdb_type ovsdb_type_integer; extern const struct ovsdb_type ovsdb_type_real; @@ -75,6 +145,9 @@ extern const struct ovsdb_type ovsdb_type_boolean; extern const struct ovsdb_type ovsdb_type_string; extern const struct ovsdb_type ovsdb_type_uuid; +void ovsdb_type_clone(struct ovsdb_type *, const struct ovsdb_type *); +void ovsdb_type_destroy(struct ovsdb_type *); + bool ovsdb_type_is_valid(const struct ovsdb_type *); static inline bool ovsdb_type_is_scalar(const struct ovsdb_type *); @@ -95,19 +168,32 @@ struct json *ovsdb_type_to_json(const struct ovsdb_type *); static inline bool ovsdb_atomic_type_is_valid(enum ovsdb_atomic_type atomic_type) { - return atomic_type >= 0 && atomic_type < OVSDB_N_TYPES; + return (int) atomic_type >= 0 && atomic_type < OVSDB_N_TYPES; +} + +static inline bool +ovsdb_base_type_is_ref(const struct ovsdb_base_type *base) +{ + return base->type == OVSDB_TYPE_UUID && base->u.uuid.refTableName; +} + +static inline bool +ovsdb_base_type_is_strong_ref(const struct ovsdb_base_type *base) +{ + return (ovsdb_base_type_is_ref(base) + && base->u.uuid.refType == OVSDB_REF_STRONG); } static inline bool -ovsdb_atomic_type_is_valid_key(enum ovsdb_atomic_type atomic_type) +ovsdb_base_type_is_weak_ref(const struct ovsdb_base_type *base) { - /* XXX should we disallow reals or booleans as keys? */ - return ovsdb_atomic_type_is_valid(atomic_type); + return (ovsdb_base_type_is_ref(base) + && base->u.uuid.refType == OVSDB_REF_WEAK); } static inline bool ovsdb_type_is_scalar(const struct ovsdb_type *type) { - return (type->value_type == OVSDB_TYPE_VOID + return (type->value.type == OVSDB_TYPE_VOID && type->n_min == 1 && type->n_max == 1); } @@ -123,13 +209,13 @@ static inline bool ovsdb_type_is_composite(const struct ovsdb_type *type) static inline bool ovsdb_type_is_set(const struct ovsdb_type *type) { - return (type->value_type == OVSDB_TYPE_VOID + return (type->value.type == OVSDB_TYPE_VOID && (type->n_min != 1 || type->n_max != 1)); } static inline bool ovsdb_type_is_map(const struct ovsdb_type *type) { - return type->value_type != OVSDB_TYPE_VOID; + return type->value.type != OVSDB_TYPE_VOID; } #endif /* ovsdb-types.h */