Spaces:
Runtime error
Runtime error
| // automatically generated by the FlatBuffers compiler, do not modify | |
| import * as flatbuffers from 'flatbuffers'; | |
| import { TimeUnit } from './time-unit.js'; | |
| /** | |
| * Timestamp is a 64-bit signed integer representing an elapsed time since a | |
| * fixed epoch, stored in either of four units: seconds, milliseconds, | |
| * microseconds or nanoseconds, and is optionally annotated with a timezone. | |
| * | |
| * Timestamp values do not include any leap seconds (in other words, all | |
| * days are considered 86400 seconds long). | |
| * | |
| * Timestamps with a non-empty timezone | |
| * ------------------------------------ | |
| * | |
| * If a Timestamp column has a non-empty timezone value, its epoch is | |
| * 1970-01-01 00:00:00 (January 1st 1970, midnight) in the *UTC* timezone | |
| * (the Unix epoch), regardless of the Timestamp's own timezone. | |
| * | |
| * Therefore, timestamp values with a non-empty timezone correspond to | |
| * physical points in time together with some additional information about | |
| * how the data was obtained and/or how to display it (the timezone). | |
| * | |
| * For example, the timestamp value 0 with the timezone string "Europe/Paris" | |
| * corresponds to "January 1st 1970, 00h00" in the UTC timezone, but the | |
| * application may prefer to display it as "January 1st 1970, 01h00" in | |
| * the Europe/Paris timezone (which is the same physical point in time). | |
| * | |
| * One consequence is that timestamp values with a non-empty timezone | |
| * can be compared and ordered directly, since they all share the same | |
| * well-known point of reference (the Unix epoch). | |
| * | |
| * Timestamps with an unset / empty timezone | |
| * ----------------------------------------- | |
| * | |
| * If a Timestamp column has no timezone value, its epoch is | |
| * 1970-01-01 00:00:00 (January 1st 1970, midnight) in an *unknown* timezone. | |
| * | |
| * Therefore, timestamp values without a timezone cannot be meaningfully | |
| * interpreted as physical points in time, but only as calendar / clock | |
| * indications ("wall clock time") in an unspecified timezone. | |
| * | |
| * For example, the timestamp value 0 with an empty timezone string | |
| * corresponds to "January 1st 1970, 00h00" in an unknown timezone: there | |
| * is not enough information to interpret it as a well-defined physical | |
| * point in time. | |
| * | |
| * One consequence is that timestamp values without a timezone cannot | |
| * be reliably compared or ordered, since they may have different points of | |
| * reference. In particular, it is *not* possible to interpret an unset | |
| * or empty timezone as the same as "UTC". | |
| * | |
| * Conversion between timezones | |
| * ---------------------------- | |
| * | |
| * If a Timestamp column has a non-empty timezone, changing the timezone | |
| * to a different non-empty value is a metadata-only operation: | |
| * the timestamp values need not change as their point of reference remains | |
| * the same (the Unix epoch). | |
| * | |
| * However, if a Timestamp column has no timezone value, changing it to a | |
| * non-empty value requires to think about the desired semantics. | |
| * One possibility is to assume that the original timestamp values are | |
| * relative to the epoch of the timezone being set; timestamp values should | |
| * then adjusted to the Unix epoch (for example, changing the timezone from | |
| * empty to "Europe/Paris" would require converting the timestamp values | |
| * from "Europe/Paris" to "UTC", which seems counter-intuitive but is | |
| * nevertheless correct). | |
| * | |
| * Guidelines for encoding data from external libraries | |
| * ---------------------------------------------------- | |
| * | |
| * Date & time libraries often have multiple different data types for temporal | |
| * data. In order to ease interoperability between different implementations the | |
| * Arrow project has some recommendations for encoding these types into a Timestamp | |
| * column. | |
| * | |
| * An "instant" represents a physical point in time that has no relevant timezone | |
| * (for example, astronomical data). To encode an instant, use a Timestamp with | |
| * the timezone string set to "UTC", and make sure the Timestamp values | |
| * are relative to the UTC epoch (January 1st 1970, midnight). | |
| * | |
| * A "zoned date-time" represents a physical point in time annotated with an | |
| * informative timezone (for example, the timezone in which the data was | |
| * recorded). To encode a zoned date-time, use a Timestamp with the timezone | |
| * string set to the name of the timezone, and make sure the Timestamp values | |
| * are relative to the UTC epoch (January 1st 1970, midnight). | |
| * | |
| * (There is some ambiguity between an instant and a zoned date-time with the | |
| * UTC timezone. Both of these are stored the same in Arrow. Typically, | |
| * this distinction does not matter. If it does, then an application should | |
| * use custom metadata or an extension type to distinguish between the two cases.) | |
| * | |
| * An "offset date-time" represents a physical point in time combined with an | |
| * explicit offset from UTC. To encode an offset date-time, use a Timestamp | |
| * with the timezone string set to the numeric timezone offset string | |
| * (e.g. "+03:00"), and make sure the Timestamp values are relative to | |
| * the UTC epoch (January 1st 1970, midnight). | |
| * | |
| * A "naive date-time" (also called "local date-time" in some libraries) | |
| * represents a wall clock time combined with a calendar date, but with | |
| * no indication of how to map this information to a physical point in time. | |
| * Naive date-times must be handled with care because of this missing | |
| * information, and also because daylight saving time (DST) may make | |
| * some values ambiguous or non-existent. A naive date-time may be | |
| * stored as a struct with Date and Time fields. However, it may also be | |
| * encoded into a Timestamp column with an empty timezone. The timestamp | |
| * values should be computed "as if" the timezone of the date-time values | |
| * was UTC; for example, the naive date-time "January 1st 1970, 00h00" would | |
| * be encoded as timestamp value 0. | |
| */ | |
| export class Timestamp { | |
| bb: flatbuffers.ByteBuffer|null = null; | |
| bb_pos = 0; | |
| __init(i:number, bb:flatbuffers.ByteBuffer):Timestamp { | |
| this.bb_pos = i; | |
| this.bb = bb; | |
| return this; | |
| } | |
| static getRootAsTimestamp(bb:flatbuffers.ByteBuffer, obj?:Timestamp):Timestamp { | |
| return (obj || new Timestamp()).__init(bb.readInt32(bb.position()) + bb.position(), bb); | |
| } | |
| static getSizePrefixedRootAsTimestamp(bb:flatbuffers.ByteBuffer, obj?:Timestamp):Timestamp { | |
| bb.setPosition(bb.position() + flatbuffers.SIZE_PREFIX_LENGTH); | |
| return (obj || new Timestamp()).__init(bb.readInt32(bb.position()) + bb.position(), bb); | |
| } | |
| unit():TimeUnit { | |
| const offset = this.bb!.__offset(this.bb_pos, 4); | |
| return offset ? this.bb!.readInt16(this.bb_pos + offset) : TimeUnit.SECOND; | |
| } | |
| /** | |
| * The timezone is an optional string indicating the name of a timezone, | |
| * one of: | |
| * | |
| * * As used in the Olson timezone database (the "tz database" or | |
| * "tzdata"), such as "America/New_York". | |
| * * An absolute timezone offset of the form "+XX:XX" or "-XX:XX", | |
| * such as "+07:30". | |
| * | |
| * Whether a timezone string is present indicates different semantics about | |
| * the data (see above). | |
| */ | |
| timezone():string|null | |
| timezone(optionalEncoding:flatbuffers.Encoding):string|Uint8Array|null | |
| timezone(optionalEncoding?:any):string|Uint8Array|null { | |
| const offset = this.bb!.__offset(this.bb_pos, 6); | |
| return offset ? this.bb!.__string(this.bb_pos + offset, optionalEncoding) : null; | |
| } | |
| static startTimestamp(builder:flatbuffers.Builder) { | |
| builder.startObject(2); | |
| } | |
| static addUnit(builder:flatbuffers.Builder, unit:TimeUnit) { | |
| builder.addFieldInt16(0, unit, TimeUnit.SECOND); | |
| } | |
| static addTimezone(builder:flatbuffers.Builder, timezoneOffset:flatbuffers.Offset) { | |
| builder.addFieldOffset(1, timezoneOffset, 0); | |
| } | |
| static endTimestamp(builder:flatbuffers.Builder):flatbuffers.Offset { | |
| const offset = builder.endObject(); | |
| return offset; | |
| } | |
| static createTimestamp(builder:flatbuffers.Builder, unit:TimeUnit, timezoneOffset:flatbuffers.Offset):flatbuffers.Offset { | |
| Timestamp.startTimestamp(builder); | |
| Timestamp.addUnit(builder, unit); | |
| Timestamp.addTimezone(builder, timezoneOffset); | |
| return Timestamp.endTimestamp(builder); | |
| } | |
| } | |