2017-11-20 09:30:52 -05:00
|
|
|
/*
|
2018-07-25 04:17:02 -04:00
|
|
|
Copyright The Kubernetes Authors.
|
2017-11-20 09:30:52 -05:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
// This file was autogenerated by go-to-protobuf. Do not edit it manually!
|
|
|
|
|
|
|
|
syntax = 'proto2';
|
|
|
|
|
|
|
|
package k8s.io.apimachinery.pkg.api.resource;
|
|
|
|
|
|
|
|
// Package-wide variables from generator "generated".
|
|
|
|
option go_package = "resource";
|
|
|
|
|
|
|
|
// Quantity is a fixed-point representation of a number.
|
|
|
|
// It provides convenient marshaling/unmarshaling in JSON and YAML,
|
2019-10-15 10:01:09 -04:00
|
|
|
// in addition to String() and AsInt64() accessors.
|
2019-03-25 08:03:02 -04:00
|
|
|
//
|
2017-11-20 09:30:52 -05:00
|
|
|
// The serialization format is:
|
2019-03-25 08:03:02 -04:00
|
|
|
//
|
2017-11-20 09:30:52 -05:00
|
|
|
// <quantity> ::= <signedNumber><suffix>
|
|
|
|
// (Note that <suffix> may be empty, from the "" case in <decimalSI>.)
|
|
|
|
// <digit> ::= 0 | 1 | ... | 9
|
|
|
|
// <digits> ::= <digit> | <digit><digits>
|
|
|
|
// <number> ::= <digits> | <digits>.<digits> | <digits>. | .<digits>
|
|
|
|
// <sign> ::= "+" | "-"
|
|
|
|
// <signedNumber> ::= <number> | <sign><number>
|
|
|
|
// <suffix> ::= <binarySI> | <decimalExponent> | <decimalSI>
|
|
|
|
// <binarySI> ::= Ki | Mi | Gi | Ti | Pi | Ei
|
|
|
|
// (International System of units; See: http://physics.nist.gov/cuu/Units/binary.html)
|
|
|
|
// <decimalSI> ::= m | "" | k | M | G | T | P | E
|
|
|
|
// (Note that 1024 = 1Ki but 1000 = 1k; I didn't choose the capitalization.)
|
|
|
|
// <decimalExponent> ::= "e" <signedNumber> | "E" <signedNumber>
|
2019-03-25 08:03:02 -04:00
|
|
|
//
|
2017-11-20 09:30:52 -05:00
|
|
|
// No matter which of the three exponent forms is used, no quantity may represent
|
|
|
|
// a number greater than 2^63-1 in magnitude, nor may it have more than 3 decimal
|
|
|
|
// places. Numbers larger or more precise will be capped or rounded up.
|
|
|
|
// (E.g.: 0.1m will rounded up to 1m.)
|
|
|
|
// This may be extended in the future if we require larger or smaller quantities.
|
2019-03-25 08:03:02 -04:00
|
|
|
//
|
2017-11-20 09:30:52 -05:00
|
|
|
// When a Quantity is parsed from a string, it will remember the type of suffix
|
|
|
|
// it had, and will use the same type again when it is serialized.
|
2019-03-25 08:03:02 -04:00
|
|
|
//
|
2017-11-20 09:30:52 -05:00
|
|
|
// Before serializing, Quantity will be put in "canonical form".
|
|
|
|
// This means that Exponent/suffix will be adjusted up or down (with a
|
|
|
|
// corresponding increase or decrease in Mantissa) such that:
|
|
|
|
// a. No precision is lost
|
|
|
|
// b. No fractional digits will be emitted
|
|
|
|
// c. The exponent (or suffix) is as large as possible.
|
|
|
|
// The sign will be omitted unless the number is negative.
|
2019-03-25 08:03:02 -04:00
|
|
|
//
|
2017-11-20 09:30:52 -05:00
|
|
|
// Examples:
|
|
|
|
// 1.5 will be serialized as "1500m"
|
|
|
|
// 1.5Gi will be serialized as "1536Mi"
|
2019-03-25 08:03:02 -04:00
|
|
|
//
|
2017-11-20 09:30:52 -05:00
|
|
|
// Note that the quantity will NEVER be internally represented by a
|
|
|
|
// floating point number. That is the whole point of this exercise.
|
2019-03-25 08:03:02 -04:00
|
|
|
//
|
2017-11-20 09:30:52 -05:00
|
|
|
// Non-canonical values will still parse as long as they are well formed,
|
|
|
|
// but will be re-emitted in their canonical form. (So always use canonical
|
|
|
|
// form, or don't diff.)
|
2019-03-25 08:03:02 -04:00
|
|
|
//
|
2017-11-20 09:30:52 -05:00
|
|
|
// This format is intended to make it difficult to use these numbers without
|
|
|
|
// writing some sort of special handling code in the hopes that that will
|
|
|
|
// cause implementors to also use a fixed point implementation.
|
2019-03-25 08:03:02 -04:00
|
|
|
//
|
2017-11-20 09:30:52 -05:00
|
|
|
// +protobuf=true
|
|
|
|
// +protobuf.embed=string
|
|
|
|
// +protobuf.options.marshal=false
|
|
|
|
// +protobuf.options.(gogoproto.goproto_stringer)=false
|
2018-07-25 04:17:02 -04:00
|
|
|
// +k8s:deepcopy-gen=true
|
2017-11-20 09:30:52 -05:00
|
|
|
// +k8s:openapi-gen=true
|
|
|
|
message Quantity {
|
|
|
|
optional string string = 1;
|
|
|
|
}
|
|
|
|
|