Skip to content

Commit

Permalink
fix schema index serialization
Browse files Browse the repository at this point in the history
  • Loading branch information
stevensJourney committed Mar 20, 2024
1 parent da9443c commit 8f9289d
Show file tree
Hide file tree
Showing 3 changed files with 44 additions and 5 deletions.
Original file line number Diff line number Diff line change
@@ -1,27 +1,45 @@
package com.powersync.db.schema

import kotlinx.serialization.SerialName
import kotlinx.serialization.Serializable

/**
* Describes an indexed column.
*/
@Serializable
data class IndexedColumn (
data class IndexedColumn(
/**
* Name of the column to index.
*/
@SerialName("name")
val column: String,

/**
* Whether this column is stored in ascending order in the index.
*/
private val ascending: Boolean = true
private val ascending: Boolean = true,

private var columnDefinition: Column? = null,

/**
* The column definition type
*/
var type: ColumnType? = null
) {
companion object {
fun ascending(column: String) = IndexedColumn(column, true)
fun descending(column: String) = IndexedColumn(column, false)
}

/**
* Sets the parent column definition. The column definition's type
* is required for the serialized JSON payload of powersync_replace_schema
*/
fun setColumnDefinition(column: Column) {
this.type = column.type;
this.columnDefinition = column;
}

fun toSql(table: Table): String {
val fullColumn = table[column] // errors if not found
return fullColumn.let {
Expand Down
18 changes: 17 additions & 1 deletion core/src/commonMain/kotlin/com/powersync/db/schema/Table.kt
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,14 @@ package com.powersync.db.schema

import com.powersync.invalidSqliteCharacters
import kotlinx.serialization.Serializable
import kotlin.math.log

/**
* A single table in the schema.
*/
@Serializable

data class Table constructor(
data class Table constructor(
/**
* The synced table name, matching sync rules.
*/
Expand All @@ -34,6 +35,21 @@ data class Table constructor(
*/
private val _viewNameOverride: String? = null
) {

init {
/**
* Need to set the column definition for each index column.
* This is required for serialization
*/
indexes.forEach { index ->
index.columns.forEach {
val matchingColumn = columns.find { c -> c.name == it.column }
?: throw AssertionError("Could not find column definition for index ${index.name}:${it.column}")
it.setColumnDefinition(column = matchingColumn)
}
}
}

companion object {
/**
* Create a table that only exists locally.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,16 +1,21 @@
package com.powersync.demos

import com.powersync.db.schema.Column
import com.powersync.db.schema.Index
import com.powersync.db.schema.IndexedColumn
import com.powersync.db.schema.Schema
import com.powersync.db.schema.Table

val AppSchema: Schema = Schema(
listOf(
Table(
"customers",
listOf(
name = "customers",
columns = listOf(
Column.text("name"),
Column.text("email")
),
indexes = listOf(
Index("name", listOf(IndexedColumn.descending("name")))
)
)
)
Expand Down

0 comments on commit 8f9289d

Please sign in to comment.