from collections.abc import Sequence
from contextlib import AbstractContextManager
from typing import Any

from django.db.backends.ddl_references import Statement
from django.db.models.base import Model
from django.db.models.fields import Field
from django.db.models.indexes import Index

logger: Any

class BaseDatabaseSchemaEditor(AbstractContextManager[Any]):
    sql_create_table: str = ...
    sql_rename_table: str = ...
    sql_retablespace_table: str = ...
    sql_delete_table: str = ...
    sql_create_column: str = ...
    sql_alter_column: str = ...
    sql_alter_column_type: str = ...
    sql_alter_column_null: str = ...
    sql_alter_column_not_null: str = ...
    sql_alter_column_default: str = ...
    sql_alter_column_no_default: str = ...
    sql_delete_column: str = ...
    sql_rename_column: str = ...
    sql_update_with_default: str = ...
    sql_create_check: str = ...
    sql_delete_check: str = ...
    sql_create_unique: str = ...
    sql_delete_unique: str = ...
    sql_create_fk: str = ...
    sql_create_inline_fk: str = ...
    sql_delete_fk: str = ...
    sql_create_index: str = ...
    sql_delete_index: str = ...
    sql_create_pk: str = ...
    sql_delete_pk: str = ...
    sql_delete_procedure: str = ...
    connection: Any = ...
    collect_sql: bool = ...
    collected_sql: Any = ...
    atomic_migration: Any = ...
    def __init__(
        self, connection: Any, collect_sql: bool = ..., atomic: bool = ...
    ) -> None: ...
    deferred_sql: Any = ...
    atomic: Any = ...
    def __enter__(self) -> BaseDatabaseSchemaEditor: ...
    def __exit__(self, exc_type: Any, exc_value: Any, traceback: Any) -> None: ...
    def execute(
        self,
        sql: Statement | str,
        params: list[int] | tuple[Any, ...] | None = ...,
    ) -> None: ...
    def quote_name(self, name: str) -> str: ...
    def column_sql(
        self, model: type[Model], field: Field[Any, Any], include_default: bool = ...
    ) -> tuple[str | None, list[Any] | None]: ...
    def skip_default(self, field: Any) -> Any: ...
    def prepare_default(self, value: Any) -> None: ...
    def effective_default(self, field: Field[Any, Any]) -> int | str | None: ...
    def quote_value(self, value: Any) -> None: ...
    def create_model(self, model: type[Model]) -> None: ...
    def delete_model(self, model: type[Model]) -> None: ...
    def add_index(self, model: type[Model], index: Index) -> None: ...
    def remove_index(self, model: type[Model], index: Index) -> None: ...
    def alter_unique_together(
        self,
        model: type[Model],
        old_unique_together: Sequence[Sequence[str]],
        new_unique_together: Sequence[Sequence[str]],
    ) -> None: ...
    def alter_index_together(
        self,
        model: type[Model],
        old_index_together: Sequence[Sequence[str]],
        new_index_together: Sequence[Sequence[str]],
    ) -> None: ...
    def alter_db_table(
        self, model: type[Model], old_db_table: str, new_db_table: str
    ) -> None: ...
    def alter_db_tablespace(
        self, model: Any, old_db_tablespace: Any, new_db_tablespace: Any
    ) -> None: ...
    def add_field(self, model: Any, field: Any) -> Any: ...
    def remove_field(self, model: Any, field: Any) -> Any: ...
    def alter_field(
        self,
        model: type[Model],
        old_field: Field[Any, Any],
        new_field: Field[Any, Any],
        strict: bool = ...,
    ) -> None: ...
    def remove_procedure(self, procedure_name: Any, param_types: Any = ...) -> None: ...
