Initial commit
This commit is contained in:
149
node_modules/drizzle-orm/pg-core/indexes.cjs
generated
vendored
Normal file
149
node_modules/drizzle-orm/pg-core/indexes.cjs
generated
vendored
Normal file
@ -0,0 +1,149 @@
|
||||
"use strict";
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
var indexes_exports = {};
|
||||
__export(indexes_exports, {
|
||||
Index: () => Index,
|
||||
IndexBuilder: () => IndexBuilder,
|
||||
IndexBuilderOn: () => IndexBuilderOn,
|
||||
index: () => index,
|
||||
uniqueIndex: () => uniqueIndex
|
||||
});
|
||||
module.exports = __toCommonJS(indexes_exports);
|
||||
var import_sql = require("../sql/sql.cjs");
|
||||
var import_entity = require("../entity.cjs");
|
||||
var import_columns = require("./columns/index.cjs");
|
||||
class IndexBuilderOn {
|
||||
constructor(unique, name) {
|
||||
this.unique = unique;
|
||||
this.name = name;
|
||||
}
|
||||
static [import_entity.entityKind] = "PgIndexBuilderOn";
|
||||
on(...columns) {
|
||||
return new IndexBuilder(
|
||||
columns.map((it) => {
|
||||
if ((0, import_entity.is)(it, import_sql.SQL)) {
|
||||
return it;
|
||||
}
|
||||
it = it;
|
||||
const clonedIndexedColumn = new import_columns.IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig);
|
||||
it.indexConfig = JSON.parse(JSON.stringify(it.defaultConfig));
|
||||
return clonedIndexedColumn;
|
||||
}),
|
||||
this.unique,
|
||||
false,
|
||||
this.name
|
||||
);
|
||||
}
|
||||
onOnly(...columns) {
|
||||
return new IndexBuilder(
|
||||
columns.map((it) => {
|
||||
if ((0, import_entity.is)(it, import_sql.SQL)) {
|
||||
return it;
|
||||
}
|
||||
it = it;
|
||||
const clonedIndexedColumn = new import_columns.IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig);
|
||||
it.indexConfig = it.defaultConfig;
|
||||
return clonedIndexedColumn;
|
||||
}),
|
||||
this.unique,
|
||||
true,
|
||||
this.name
|
||||
);
|
||||
}
|
||||
/**
|
||||
* Specify what index method to use. Choices are `btree`, `hash`, `gist`, `spgist`, `gin`, `brin`, or user-installed access methods like `bloom`. The default method is `btree.
|
||||
*
|
||||
* If you have the `pg_vector` extension installed in your database, you can use the `hnsw` and `ivfflat` options, which are predefined types.
|
||||
*
|
||||
* **You can always specify any string you want in the method, in case Drizzle doesn't have it natively in its types**
|
||||
*
|
||||
* @param method The name of the index method to be used
|
||||
* @param columns
|
||||
* @returns
|
||||
*/
|
||||
using(method, ...columns) {
|
||||
return new IndexBuilder(
|
||||
columns.map((it) => {
|
||||
if ((0, import_entity.is)(it, import_sql.SQL)) {
|
||||
return it;
|
||||
}
|
||||
it = it;
|
||||
const clonedIndexedColumn = new import_columns.IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig);
|
||||
it.indexConfig = JSON.parse(JSON.stringify(it.defaultConfig));
|
||||
return clonedIndexedColumn;
|
||||
}),
|
||||
this.unique,
|
||||
true,
|
||||
this.name,
|
||||
method
|
||||
);
|
||||
}
|
||||
}
|
||||
class IndexBuilder {
|
||||
static [import_entity.entityKind] = "PgIndexBuilder";
|
||||
/** @internal */
|
||||
config;
|
||||
constructor(columns, unique, only, name, method = "btree") {
|
||||
this.config = {
|
||||
name,
|
||||
columns,
|
||||
unique,
|
||||
only,
|
||||
method
|
||||
};
|
||||
}
|
||||
concurrently() {
|
||||
this.config.concurrently = true;
|
||||
return this;
|
||||
}
|
||||
with(obj) {
|
||||
this.config.with = obj;
|
||||
return this;
|
||||
}
|
||||
where(condition) {
|
||||
this.config.where = condition;
|
||||
return this;
|
||||
}
|
||||
/** @internal */
|
||||
build(table) {
|
||||
return new Index(this.config, table);
|
||||
}
|
||||
}
|
||||
class Index {
|
||||
static [import_entity.entityKind] = "PgIndex";
|
||||
config;
|
||||
constructor(config, table) {
|
||||
this.config = { ...config, table };
|
||||
}
|
||||
}
|
||||
function index(name) {
|
||||
return new IndexBuilderOn(false, name);
|
||||
}
|
||||
function uniqueIndex(name) {
|
||||
return new IndexBuilderOn(true, name);
|
||||
}
|
||||
// Annotate the CommonJS export names for ESM import in node:
|
||||
0 && (module.exports = {
|
||||
Index,
|
||||
IndexBuilder,
|
||||
IndexBuilderOn,
|
||||
index,
|
||||
uniqueIndex
|
||||
});
|
||||
//# sourceMappingURL=indexes.cjs.map
|
||||
Reference in New Issue
Block a user