@lindentech/somon-script
v0.3.60
Published
A programming language that compiles to JavaScript, written in Tajik Cyrillic
Maintainers
Readme
СомонСкрипт
Забони барномарезии синфи истеҳсолот бо синтаксиси тоҷикӣ
Забони барномарезии пурра бо хусусиятҳои муосири бехатарии навъ ва синтаксиси кирилликаи тоҷикӣ, ки ба JavaScript-и беҳинашуда компил мешавад. Лоиҳа фаъолона рушд меёбад, бо маҷмӯи автоматии тестҳо ва ҳуҷҷатгузории муфассал дастгирӣ мешавад.
🗣️ Забонҳои дигар
Нест кардани монеаҳои забонӣ дар рушди нармафзор
СомонСкрипт махсусан барои нест кардани монеаи забонӣ сохта шудааст, ки бисёре аз барномарезони истеъдоднокро аз ифода кардани пурраи қобилиятҳои барномарезии онҳо боздоштааст. Бо таъмини муҳити пурраи барномарезӣ дар хати кирилликаи тоҷикӣ, СомонСкрипт ба барномарезон имкон медиҳад, ки дар забони модариашон фикр кунанд, код нависанд ва ҳамкорӣ намоянд ва дар айни ҳол аз қувваи пурраи парадигмаҳои муосири барномарезӣ истифода баранд.
Ин муносибати инноватсионӣ на танҳо фаҳмиши кодро беҳтар мекунад ва боркунии когнитивиро кам мекунад, балки дарвозаҳоро барои насли навини барномарезон мекушояд, ки акнун метавонанд ба экосистемаи ҷаҳонии нармафзор саҳм гузоранд, бе он ки аз синтаксиси забони хориҷӣ маҳдуд шаванд.
✨ Чаро СомонСкриптро интихоб кунед?
🌍 Нест кардани монеаҳои забонӣ дар барномарезӣ
Тавонманд кардани рушди забони модарӣ
СомонСкрипт рушди нармафзорро инқилоб мекунад бо нест кардани монеаи асосии забонӣ:
- Табиӣ фикр кардан: Алгоритмҳо ва мантиқи мураккабро дар шаклҳои забони модарӣ ифода кунед
- Кам кардани боркунии когнитивӣ: Қабати тарҷумаи ақлиро байни концепсия ва код нест кунед
- Беҳтар кардани фаҳмиши код: Коди худмуаррифшударо нависед, ки барои дастаҳои тоҷикзабон фавран хондашаванда аст
- Суръат додан ба омӯхтан: Барномарезони нав метавонанд ба консепсияҳои барномарезӣ тамаркуз кунанд, на ба синтаксиси хориҷӣ
🔒 Бехатарии навъи синфи касбӣ
Системи пешрафтаи таҳлили статикӣ бо хусусиятҳои бехатарии сатҳи TypeScript:
- Навъҳои иттиҳод ва буриш
- Навъҳои tuple бо хулосаи дарозӣ
- Мерос ва таркиби интерфейс
- Параметрҳои навъи умумӣ
- Ифодаҳои навъи шартӣ
⚡ Манзараи рушди ҷорӣ
- Аудити худкори намунаҳо –
npm run audit:examplesбарномаҳои намунавиро пеш аз нашр санҷида мебарояд. - Маҷмӯи васеи тестҳо – зиёда аз 300 тест марҳилаҳои лексер, парсер, санҷиши навъ ва CLI-ро мепӯшонад. Ҳисоботҳои пӯшиш бо дархост дастрасанд.
- Услуб ва формати ягона – ESLint ва Prettier покии кодро нигоҳ медоранд.
- Меъмории қабатӣ – Компилятор, CLI ва системаи модулӣ ҳамчун қисмҳои ҷудогона нигоҳ дошта мешаванд.
- Рушди фаъол – Барои арзёбӣ ва лоиҳаҳои пилотӣ мувофиқ аст; дар бораи мушкилоти дар муҳитҳои истеҳсолӣ дучоршуда хабар диҳед.
🎨 Васеъшавии VS Code
Дастгирии пурраи IDE бо рӯшноии синтаксис, IntelliSense ва фрагментҳои код:
- Насб аз Бозори VS Code: "SomonScript"-ро ҷустуҷӯ кунед ё бевосита насб кунед
- Хусусиятҳо: Рӯшноии синтаксис, толеби худшиносъанд-намуд, 30+ фрагмент, вазнданиҳои ҳам-замон
- Маълумоти Hovering: Ҳуҷҷатгузории кунҷи тоҷикӣ бо эквивалентҳои JavaScript-ро бубинед
🚀 Шурӯъи зуд
Насб
# NPM (тавсияшуда барои аксари корбарон)
npm install -g @lindentech/somon-script
# JSR (тавсияшуда барои лоиҳаҳои TypeScript)
npx jsr add @lindentechde/somon-script
# Ё дар лоиҳа истифода баред
npm install @lindentech/somon-script --save-devИнтерфейси бисёрзабонаи CLI
CLI СомонСкрипт акнун се забонро дастгирӣ мекунад: Англисӣ, Тоҷикӣ ва Русӣ. Ин ба барномарезон имкон медиҳад, ки компиляторро дар забони дӯстдоштаашон истифода баранд.
Танзими забон
# Истифодаи интерфейси тоҷикӣ
somon --lang tj компайл app.som
# Истифодаи интерфейси русӣ
somon --lang ru компилировать app.som
# Истифодаи интерфейси англисӣ (бо нобаёнӣ)
somon --lang en compile app.somМуайян кардани худкори забон
CLI забони системаи шуморо аз тағйирёбандаҳои муҳитӣ худкор муайян мекунад:
# Танзими забони дӯстдошта тавассути муҳит
export SOMON_LANG=tj # Тоҷикӣ
export SOMON_LANG=ru # Русӣ
export SOMON_LANG=en # Англисӣ
# Ё истифодаи забони системавӣ
export LANG=tg_TJ.UTF-8 # Худкор тоҷикиро истифода мебарад
export LANG=ru_RU.UTF-8 # Худкор русиро истифода мебарадФармонҳои дастрас дар ҳар забон
compile app.som
run app.som
init my-project
bundle src/main.som
module-info src/main.som
resolve "./utils"
serve --port 8080компайл app.som
иҷро app.som
оғоз лоиҳаи-ман
баста src/main.som
маълумоти-модул src/main.som
ҳал "./utils"
хидмат --port 8080компилировать app.som
запустить app.som
инициализация мой-проект
пакет src/main.som
информация-модуля src/main.som
разрешить "./utils"
сервер --port 8080Намунаҳои истифода
# Бо забони тоҷикӣ
somon --lang tj компайл файли-ман.som -o dist/файл.js
somon --lang tj иҷро барнома.som
somon --lang tj баста src/асосӣ.som --minify
# Паёмҳо ҳам дар забони интихобшуда нишон дода мешаванд:
# ✅ 'app.som' ба 'app.js' компайл шуд
# 📦 src/main.som-ро баста мекунем...
# 🔍 src/main.som-ро таҳлил мекунем...Барномаи аввалини шумо
# Намунаи Салом ҷаҳон
echo 'чоп.сабт("Салом, ҷаҳон!");' > hello.som
somon run hello.som
# Мантиқи тиҷоратӣ бо бехатарии навъ
cat > calculator.som << 'EOF'
функсия ҷамъ(а: рақам, б: рақам): рақам {
бозгашт а + б;
}
тағ натиҷа = ҷамъ(5, 3);
чоп.сабт("Натиҷа: " + натиҷа);
EOF
somon run calculator.somБандлинг (Системаи модул)
- SomonScript бастаҳои CommonJS-и омода ба иҷро месозад.
somon bundle src/main.som -o dist/bundle.jsБарои дебаг --source-map-ро истифода баред, то харитаи манбаъҳоро гиред:
somon bundle src/main.som -o dist/bundle.js --source-mapХаритаҳо акнун роҳҳои модулро нисбат ба феҳристи файли асосӣ нигоҳ медоранд, аз
ин рӯ роҳҳои мутлақ ифшо намешаванд. Флаги --inline-sources (ё
inlineSources: true дар конфиг) матни SomonScript-ро ба .map замим мекунад,
агар ба шумо ниёз бошад, ки манбаъ дар артефакт мавҷуд бошад.
Омодагӣ барои истеҳсолот
СомонСкрипт барои истеҳсолот омода аст бо хусусиятҳои амалиётии ҳамаҷониба:
- ✅ Татбиқи пурраи забон - Ҳамаи хусусиятҳои синтаксиси тоҷикӣ кор мекунанд
- ✅ Коркарди хатоҳо - Деградатсияи боадаб ва гузоришдиҳии ҳамаҷониба
- ✅ Мониторинг ва мушоҳида - Санҷишҳои саломатӣ, метрикаҳо, логгинги сохторӣ
- ✅ Идораи захираҳо - Маҳдудиятҳои хотира, таймаутҳо, хомӯшкунии боадаб
- ✅ Тоқат ба хатоҳо - Circuit breaker-ҳо, барқарорсозӣ аз хатоҳо
- ✅ Дастгирии ҷойгиркунӣ - Docker, Kubernetes, systemd, PM2
📖 Тафсилот: PRODUCTION-READINESS.md
🎯 Хусусиятҳои забон
Қобилиятҳои асосии забон
// Тағйирёбандаҳо бо хулосаи навъ
тағ ном = "Дониёр";
собит МАКС_СИННУ_СОЛ: рақам = 120;
// Функсияҳо бо аннотсияҳои навъ
функсия ҳисоб_кардан(а: рақам, б: рақам): рақам {
бозгашт а + б;
}Воситаҳои барномарезии объекторавона
синф Ҳайвон {
хосусӣ ном: сатр;
конструктор(ном: сатр) {
ин.ном = ном;
}
ҷамъиятӣ овоз_додан(): сатр {
бозгашт "Садои умумӣ";
}
}🚀 Ҷойгиркунӣ барои истеҳсолот
Режими истеҳсолот
СомонСкрипт дорои хусусиятҳои ҳамаҷонибаи истеҳсолот аст, ки бо флаги
--production фаъол мешаванд:
# Компилятсия дар режими истеҳсолот
somon compile app.som --production
# Иҷро дар режими истеҳсолот
somon run app.som --production
# Бандл дар режими истеҳсолот
somon bundle app.som --production
# Ё тавассути тағйирёбандаи муҳит
NODE_ENV=production somon compile app.somРежими истеҳсолот худкор фаъол мекунад:
- ✅ Санҷиши муҳит (версияи Node, иҷозатҳо)
- ✅ Circuit breaker-ҳо барои тоқат ба хатоҳо
- ✅ Маҳдудиятҳои захираҳо (хотира, дастгираҳои файл)
- ✅ Логгинги сохтории JSON
- ✅ Ҷамъоварии метрикаҳо
- ✅ Коркарди хомӯшкунии боадаб
Вариантҳои ҷойгиркунӣ
Docker
docker run -d \
--name somon \
-p 8080:8080 \
-e NODE_ENV=production \
somon-script:latestKubernetes
apiVersion: apps/v1
kind: Deployment
metadata:
name: somon-script
spec:
replicas: 3
template:
spec:
containers:
- name: somon
image: somon-script:latest
env:
- name: NODE_ENV
value: productionSystemd
# Насби хидмат
sudo cp somon-script.service /etc/systemd/system/
sudo systemctl enable somon-script
sudo systemctl start somon-script📖 Дастури пурра: DEPLOYMENT.md
📊 Санҷишҳои сифат
Лоиҳа дорои санҷишҳои автоматиест, ки шумо метавонед маҳалли иҷро кунед:
| Санҷиш | Фармон | Мақсад |
| ---------------------- | ------------------------ | ----------------------------------------------------------- |
| Аудити намунаҳо | npm run audit:examples | Мутмаин мешавад, ки барномаҳои намунавӣ ҳамоно кор мекунанд |
| Маҷмӯи тестҳо | npm test | Фазаҳои компилятор, CLI ва рафтори иҷроиро месанҷад |
| Linting ва формат | npm run lint | Қоидаҳои услуб ва таҳлили статикӣ-ро месанҷад |
| Сохтани TypeScript | npm run build | Пеш аз нашр манбаи TypeScript-ро компил мекунад |
🛠️ Рушд ва саҳмгузорӣ
Талаботи пешакӣ
- Node.js 20.x, 22.x, 23.x ё 24.x
- npm 8.x ё баландтар
- Дониши TypeScript (барои рушди дохилӣ)
Танзимот
# Клон кардани репозиторий
git clone https://github.com/lindentechde/Somon-Script.git
cd Somon-Script
# Насби вобастагиҳо
npm install
# Сохтани компилятор
npm run build
# Иҷрои тестҳо
npm test
# Режими рушд (назорат барои тағйирот)
npm run devТестгузаронӣ
# Маҷмӯи пурраи тестҳо
npm test
# Бо пӯшиш
npm run test:coverage
# Категорияҳои мушаххаси тест
npm run test:unit
npm run test:integration
npm run audit:examples📚 Захираҳои омӯзишӣ
Барои дастаҳои тиҷоратӣ
- 🎓 Дастур - Роҳи омӯзиши сохторӣ
- 📋 Намунаҳо - 32+ намунаи коди омода барои истеҳсолот
- 🎯 Маълумотномаи зуд - Дастури синтаксиси асосӣ
Барои дастаҳои техникӣ
- 📘 Маълумотномаи забон - Ҳуҷҷатгузории пурраи API
- 🔧 Дастурҳои амалӣ - Шаблонҳои татбиқ
- ⚡ Таҷрибаи беҳтарин - Дастурҳои кодгузории стандартӣ
Барои дастаҳои рушд
- 🏛️ Дастури меъморӣ - Принсипҳои тарроҳии система
- 🧪 Дастури тестгузаронӣ - Методологияи таъмини сифат
- 🤝 Иштироки ҷомеа - Дастурҳои иштирок
Функсияҳои ворид ва API-ҳо
- 📖 Маълумотномаи методҳои чоп -
Маълумотномаи мукаммали ҳамаи методҳои
чоп.*(сабт, хато, огоҳӣ, маълумот, исфти, тасдиқ, ҳисоб, вақт, ҷадвал, пайҷо ва бисёр дигар) - 🖨️ Намунаҳои содаи чоп - Намунаҳои оддӣ барои оғоз
- 📊 Истифодаи пешрафтаи чоп - Дастури мукаммал бо ҳамаи методҳои чоп
🌍 Дастгирии касбӣ
Хидматҳои техникӣ
- 💬 Муҳокимаҳои GitHub - Муҳокимаҳо ва саволу ҷавоб
- 🐛 Мушкилот - Гузоришҳои хатогӣ ва дархостҳои хусусият
- 📧 Почтаи электронӣ: [email protected]
Хидматҳои касбӣ
LindenTech IT Consulting хидматҳои касбии рушдро пешниҳод мекунад:
- Рушди асосӣ: Беҳтар кардани қобилиятҳо ва самаранокии компилятор
- Ҳуҷҷатгузорӣ: Беҳтар кардани ҳуҷҷатҳо ва дастурҳои техникӣ
- Тестгузаронӣ: Васеъ кардани пӯшиши тест ва таъмини сифат
- Ҳамгироӣ: Сохтани асбобҳо ва дастгирии IDE
- Самаранокӣ: Оптимизатсияи компилятсия ва иҷрои вақти кор
🚀 Нав: Раванди нашри автоматӣ
СомонСкрипт акнун semantic-release-ро барои нашрҳои автоматӣ истифода мебарад:
- Conventional Commits: Дар паёмҳои commit
feat:,fix:,docs:ва ғайраро истифода баред - Версияи автоматӣ: Версияи семантикӣ дар асоси навъҳои commit
- Нашр дар чанд регистр: Нашри автоматӣ дар NPM, JSR ва GitHub Packages
- Нашрҳои дастӣ лозим нестанд: Танҳо commit ва push кунед - система худ кор мекунад!
📖 Ҳуҷҷатгузорӣ:
- Дастури раванди нашр - Тафсилоти пурраи автоматизатсия
- CONTRIBUTING.md - Дастурҳои иштироки ҷомеа
- AGENTS.md - Қоидаҳои услуби код ва паёмҳои commit
📄 Иҷозатнома
SomonScript таҳти иҷозатномаи MIT паҳн мешавад. Матни пурра дар файли LICENSE дастрас аст.
🏢 Шарикии корхона
Дар ҳамкорӣ бо LindenTech IT Consulting сохта шудааст
СомонСкрипт дар ҳамкорӣ бо LindenTech IT Consulting сохта шудааст - консалтинги пешбари технологияи корхона.
Веб-сайт: lindentech.de
Тамос: [email protected]
🌟 Олии техникӣ
Дар асоси принсипҳои исботшудаи муҳандисии нармафзор ва технологияи муосири компилятор сохта шудааст:
- Системаи пешрафтаи навъ - Дар асоси тадқиқоти исботшудаи назарияи навъ
- Меъмории тоза - Тарроҳии модулӣ бо принсипҳои SOLID
- Стандартҳои саноатӣ - Мувофиқ бо экосистемаи JavaScript-и мавҷуда
- Оптимизатсияи самаранокӣ - Компилятсия ва иҷрои самараноки вақти кор
Стеки технология
- Татбиқи асосии TypeScript барои эътимод
- Мувофиқати экосистемаи Node.js
- Компилятсияи мақсадноки JavaScript-и муосир
- Чаҳорчӯбаи ҳамаҷонибаи тестгузаронӣ
СомонСкрипт - Барномарезии касбӣ бо синтаксиси маҳаллӣ
Ҳалли касбии рушди нармафзор
Веб-сайт (дар рушд) • GitHub • Ҳуҷҷатгузорӣ • Дастгирӣ
