Metadata-Version: 2.4
Name: thaithon
Version: 0.3.0
Summary: Thai-first Python helper libraries with Thai function names
Author: Pythai Contributors
Author-email: OteEnded <ratnaritjumnong@gmail.com>
License-Expression: Apache-2.0
Keywords: thai,python,education,helpers,localization
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Topic :: Education
Classifier: Topic :: Software Development :: Libraries
Requires-Python: >=3.10
Description-Content-Type: text/markdown
License-File: LICENSE
License-File: NOTICE
Dynamic: license-file

# Thaithon

<p align="center">
  <img src="https://raw.githubusercontent.com/OteEnded/Thaithon/main/logo.png" alt="Thaithon logo" width="200"/>
</p>

โปรเจกต์นี้เป็น playground สำหรับทำ helper/library ภาษาไทยบน Python โดยตั้งชื่อฟังก์ชันให้เป็นคำไทยที่อ่านง่าย และใช้งานได้ใกล้เคียง library มาตรฐาน

## โครงสร้างโปรเจกต์

- `libs/`
  - รวม library หลักทั้งหมด
  - `ไพท่อน.py`, `ไพท่อน_builtins.py`
  - `คณิต.py`, `เวลา.py`, `สุ่ม.py`, `สถิติ.py`
  - `เจสัน.py`, `เรกซ์.py`, `เส้นทาง.py`, `ซีเอสวี.py`
- `examples/`
  - ตัวอย่างใช้งานสั้น ๆ
  - `x.py`, `y.py`
- `tests/`
  - สคริปต์ทดสอบแต่ละโมดูล
- `tools/`
  - utility/debug scripts
- `docs/`
  - บันทึก handoff หรือเอกสารประกอบ

## หมวด library ที่มีแล้ว

- Built-ins ภาษาไทย (`ไพท่อน.py`)
- Math (`คณิต.py`)
- DateTime + sleep (`เวลา.py`)
- Random (`สุ่ม.py`)
- Statistics (`สถิติ.py`)
- JSON (`เจสัน.py`)
- Regex (`เรกซ์.py`)
- File/Path (`เส้นทาง.py`)
- CSV (`ซีเอสวี.py`)
- System/OS (`ระบบ.py`)
- Web/HTTP (`เว็บ.py`)
- Argument parsing (`อาร์กิวเมนต์.py`)

## หมายเหตุ Unicode

ภาษาไทยบางคำ (เช่นที่มี `ำ`) มีโอกาสพิมพ์คนละ Unicode form ได้ จึงมี alias สำรองบางชื่อเพื่อรองรับการใช้งานร่วมกัน

## วิธีรันตัวอย่าง

เปิด terminal ที่ root ของโปรเจกต์ แล้วรัน:

```bash
python examples/y.py
python examples/x.py
```

## วิธีรันเทส

```bash
python tests/test_data_libs.py
python tests/test_math.py
python tests/test_math_extended.py
python tests/test_datetime.py
python tests/test_random_stats.py
python tests/test_helpers.py
python tests/test_sleep.py
```

## เริ่มใช้งานกับ Git

โปรเจกต์นี้ถูกเตรียมโครงสร้างและไฟล์พื้นฐานสำหรับ Git แล้ว (`.gitignore`, `.gitattributes`, `.editorconfig`, `LICENSE`, `CHANGELOG.md`, `CONTRIBUTING.md`)

คำสั่งเริ่มต้นที่แนะนำ:

```bash
git status
git add .
git commit -m "chore: initialize Pythai project structure"
```

## Pre-package Checklist

ก่อนเริ่มทำเป็น package จริง แนะนำให้เช็ก:

- ตั้งชื่อ package ที่จะ publish (เช่น `pythai` หรือชื่อไทยแบบทับศัพท์)
- รวม API ที่ต้องการเปิด public ให้ชัดในแต่ละไฟล์ `__all__`
- ให้ test หลักผ่านทั้งหมด
- เก็บ changelog ให้เป็นเวอร์ชัน (`Unreleased` -> `x.y.z`)
- เลือกแนวทาง versioning (เช่น SemVer)

## เตรียมปล่อยขึ้น PyPI

โปรเจกต์นี้มีไฟล์ `pyproject.toml` แล้ว และสามารถ build ได้ด้วย PEP 517

1. Build package

```bash
python -m build
```

2. ตรวจสอบไฟล์ build

```bash
python -m twine check dist/*
```

3. ทดลองปล่อยขึ้น TestPyPI

```bash
python -m twine upload --repository testpypi dist/*
```

4. ปล่อยขึ้น PyPI จริง

```bash
python -m twine upload dist/*
```

หมายเหตุ:
- เพิ่ม version ทุกครั้งก่อนปล่อย release ใหม่

## License และ Attribution

- โปรเจกต์นี้ใช้สัญญาอนุญาต Apache-2.0
- กรุณาเก็บไฟล์ `LICENSE` และ `NOTICE` ไว้เมื่อมีการแจกจ่ายต่อ
- หากใช้งานในงานวิจัย/บทความ แนะนำให้อ้างอิงจากไฟล์ `CITATION.cff`

## Credit

- Maintainer: OteEnded
- Contact: ratnaritjumnong@gmail.com

## แนวทาง naming

- ใช้คำไทยความหมายตรง เช่น `พิมพ์`, `รับค่า`, `จำนวนเต็ม`, `จำนวนจริง`
- ลดคำทับศัพท์เท่าที่ทำได้
- เก็บ compatibility alias ในกรณีที่จำเป็น
