Files
relspecgo/TODO.md
Hein c9eed9b794
All checks were successful
CI / Test (1.24) (push) Successful in -25m57s
CI / Test (1.25) (push) Successful in -25m54s
CI / Build (push) Successful in -26m25s
CI / Lint (push) Successful in -26m13s
Integration Tests / Integration Tests (push) Successful in -26m1s
feat(sqlite): add SQLite writer for converting PostgreSQL schemas
- Implement SQLite DDL writer to convert PostgreSQL schemas to SQLite-compatible SQL statements.
- Include automatic schema flattening, type mapping, auto-increment detection, and function translation.
- Add templates for creating tables, indexes, unique constraints, check constraints, and foreign keys.
- Implement tests for writer functionality and data type mapping.
2026-02-07 09:11:02 +02:00

2.1 KiB

RelSpec - TODO List

Input Readers / Writers

  • [✔️] Database Inspector
    • [✔️] PostgreSQL driver (reader + writer)
    • MySQL driver
    • [✔️] SQLite driver (reader + writer with automatic schema flattening)
    • MSSQL driver
    • [✔️] Foreign key detection
    • [✔️] Index extraction
    • [✔️] .sql file generation (PostgreSQL, SQLite)
  • [✔️] .dbml: Database Markup Language (DBML) for textual schema representation.
  • [✔️] Prisma schema support (PSL format) .prisma
  • [✔️] Drizzle ORM support .ts (TypeScript / JavaScript) (Mr. Edd wanted to move from Prisma to Drizzle. If you are bugs, you are welcome to do pull requests or issues)
  • [☠️] Entity Framework (.NET) model .edmx (Fuck no, EDMX files were bloated, verbose XML nightmares—hard to merge, error-prone, and a pain in teams. Microsoft wisely ditched them in EF Core for code-first. Classic overkill from old MS era.)
  • [✔️] TypeORM support
  • [] .hbm.xml / schema.xml: Hibernate/Propel mappings (Java/PHP) (💲 Someone can do this, not me)
  • Django models.py (Python classes), Sequelize migrations (JS) (💲 Someone can do this, not me)
  • [] .avsc: Avro schema (JSON format for data serialization) (💲 Someone can do this, not me)
  • [✔️] GraphQL schema generation

UI

  • [✔️] Basic UI (I went with tview)
  • [✔️] Save / Load Database
  • [✔️] Schemas / Domains / Tables
  • Add Relations
  • Add Indexes
  • Add Views
  • Add Sequences
  • Add Scripts
  • Domain / Table Assignment

Documentation

  • API documentation (godoc)
  • Usage examples for each format combination

Advanced Features

  • Dry-run mode for validation
  • Diff tool for comparing specifications
  • Migration script generation
  • Custom type mapping configuration
  • Batch processing support
  • Watch mode for auto-regeneration

Future Considerations

  • Web UI for visual editing
  • REST API server mode
  • Support for NoSQL databases

Performance

  • Concurrent processing for multiple tables
  • Streaming for large databases
  • Memory optimization
  • Caching layer for repeated operations