X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=ovsdb%2FSPECS;h=3a9af9f39a7acd91ca67e79a38926aab680c2262;hb=24045e35021a318316f51d2e075fca07a736b91c;hp=2c83cf2a66c0514dc2ff22f0f660f0a6106db6c7;hpb=6aa09313722406629133b375871547fb426800ef;p=openvswitch diff --git a/ovsdb/SPECS b/ovsdb/SPECS index 2c83cf2a..3a9af9f3 100644 --- a/ovsdb/SPECS +++ b/ovsdb/SPECS @@ -131,6 +131,7 @@ is represented by , as described below. "columns": {: , ...} required "maxRows": optional + "isRoot": optional The value of "columns" is a JSON object whose names are column names and whose values are s. @@ -152,12 +153,28 @@ is represented by , as described below. the database process is stopped and then started again, each "_version" also changes to a new random value. + If "isRoot" is omitted or specified as false, then any given row + in the table may exist only when there is at least one reference + to it, with refType "strong", from a different row (in the same + table or a different table). This is a "deferred" action: + unreferenced rows in the table are deleted just before transaction + commit. If "isRoot" is specified as true, then rows in the table + exist independent of any references (they can be thought of as + part of the "root set" in a garbage collector). + + For compatibility with schemas created before "isRoot" was + introduced, if "isRoot" is omitted or false in every + in a given , then every table is + part of the root set. + If "maxRows" is specified, as a positive integer, it limits the maximum number of rows that may be present in the table. This is a "deferred" constraint, enforced only at transaction commit time (see the "transact" request below). If "maxRows" is not specified, the size of the table is limited only by the resources - available to the database server. + available to the database server. "maxRows" constraints are + enforced after unreferenced rows are deleted from tables with a + false "isRoot". @@ -679,7 +696,7 @@ Notation for the Wire Protocol A 2-element JSON array that represents the UUID of a row inserted in an "insert" operation within the same transaction. The first element of the array must be the string "named-uuid" and the - second element should be the string specified as the "uuid-name" + second element should be the specified as the "uuid-name" for an "insert" operation within the same transaction. For example, if an "insert" operation within this transaction specifies a "uuid-name" of "myrow", the following