TenantAtlas/apps/platform/.pnpm-store/v10/files/73/9bcd08648371f924d41b0f535514b45ded1ecf217357f2e6f578b03afe54e36cc8d12b467e222e57e944dbeabb1e51a2e4ad3acf76d6c529c1e2d0e6d9e469
Ahmed Darrazi 9f74f7a658
Some checks failed
PR Fast Feedback / fast-feedback (pull_request) Failing after 51s
feat: compress governance operator outcomes
2026-04-19 14:15:11 +02:00

43 lines
1.3 KiB
Plaintext

import { entityKind } from "../../entity.js";
import { getColumnNameAndConfig } from "../../utils.js";
import { MySqlColumnBuilderWithAutoIncrement, MySqlColumnWithAutoIncrement } from "./common.js";
class MySqlFloatBuilder extends MySqlColumnBuilderWithAutoIncrement {
static [entityKind] = "MySqlFloatBuilder";
constructor(name, config) {
super(name, "number", "MySqlFloat");
this.config.precision = config?.precision;
this.config.scale = config?.scale;
this.config.unsigned = config?.unsigned;
}
/** @internal */
build(table) {
return new MySqlFloat(table, this.config);
}
}
class MySqlFloat extends MySqlColumnWithAutoIncrement {
static [entityKind] = "MySqlFloat";
precision = this.config.precision;
scale = this.config.scale;
unsigned = this.config.unsigned;
getSQLType() {
let type = "";
if (this.precision !== void 0 && this.scale !== void 0) {
type += `float(${this.precision},${this.scale})`;
} else if (this.precision === void 0) {
type += "float";
} else {
type += `float(${this.precision})`;
}
return this.unsigned ? `${type} unsigned` : type;
}
}
function float(a, b) {
const { name, config } = getColumnNameAndConfig(a, b);
return new MySqlFloatBuilder(name, config);
}
export {
MySqlFloat,
MySqlFloatBuilder,
float
};
//# sourceMappingURL=float.js.map