Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/erhanbaris/karamel
Karamel Programlama Dili
https://github.com/erhanbaris/karamel
karamel karamel-programlama-dili karamel-programming-language
Last synced: 6 days ago
JSON representation
Karamel Programlama Dili
- Host: GitHub
- URL: https://github.com/erhanbaris/karamel
- Owner: erhanbaris
- License: bsd-3-clause
- Created: 2020-10-29T19:27:28.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2023-04-22T01:50:28.000Z (over 1 year ago)
- Last Synced: 2024-08-01T19:58:28.237Z (3 months ago)
- Topics: karamel, karamel-programlama-dili, karamel-programming-language
- Language: Rust
- Homepage: https://erhanbaris.github.io/karamel/karamelweb/src/www/
- Size: 2.85 MB
- Stars: 25
- Watchers: 8
- Forks: 5
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: changes.md
- Contributing: contributing.md
- License: LICENSE
- Code of conduct: code_of_conduct.md
Awesome Lists containing this project
README
# Karamel Programlama Dili \(KPD\)
Karamel Programlama Dili \(kısaca KPD\) sıfırdan kendi sanal makinesi üzerinde çalışan, birden fazla platformda çalışan, dinamik olarak değişkenlerin tanımlandığı, Türkçe konuşanlara yönelik geliştirilmekte olan bir programlama dilidir. Python dilinde bulunan özelliklerden ilham alınarak geliştirilmeye başlanan dil, şu anda windows ve macosx üzerinde sorunsuz olarak çalışmaktadır. Asıl amacı yeni başlayanlara kullanımı ve öğrenmesi kolay bir geliştirme ortamı sağlamaktadır. Dilin tamamı Rust Programlama Dili kullanılarak geliştirilmektedir. Kendi sanal makinesi üzerinde çalışan dil ve WebAssembly yardımı ile web üzerinde de kullanılabilir.
### Peki hangi ne tip sanal makine kullanıyor?
KPD, stack machine isimli sanal makine mimarisini kullanıyoruz. Bunu kullanmamızın nedeni yeni özelliklerin daha hızlı bir şekilde entegre edebilmemizden dolayı. Diğer Register Machine yaklaşımına kıyasla daha yavaş olsada ilk amacımız performanstan ziyade özellik ekleyip, stabil hale getirmek.
### Peki Stack Machine tam olarak nasıl çalışıyor?
Bu mimaride kullanılacak olan değişkenler bir yığın olarak üst üste istiflenir ve sonrasında LIFO \(Last In First Out\) yaklaşımına göre değişkenler istiflerden geri alınıp işleme tabii tutulur. Bu yapının avantajı kodlar en basit haline dönüştürülerek daha performanslı olarak çalışması sağlanmaktadır. Yazılımcının yazdığı yüksek seviyeli olan kodlar işlenerek ara kodlara dönüştürülmektedir. Dönüştürülen ara kodlar KPD sanal makinesinde çalıştırılmaktadır. Aslında Üst düzey yazmış olduğunuz kodlar ve sanal makinenin işledi kodlar olarak iki farklı programlama dili içermektedir.
### Peki bunu başka hangi diller kullanıyor?
Python, PHP, Ruby gibi oldukça popüler olan diller Stack Machine yaklaşımını kullanmaktadırlar.
### Dilin şu andaki durumu nedir?
Halen geliştirme aşamasında olup, yardımlara her zaman açığız. Mutlaka kodlama yapmanıza gerek yok. Fikirleriniz ilede gelip destek olabilirsiniz.
### İndirilebilir durumda mı?
Ne yazık ki indirilebilir değil fakat tarayıcı üzerinden çalıştırabilirsiniz. Aşağıda ki linki tarayıcınızda açarsanız denemeye devam başlayabilirsiniz.
[https://erhanbaris.github.io/karamel/karamelweb/src/www/](https://erhanbaris.github.io/karamel/karamelweb/src/www/)
### Temel Tipler
* Tam Sayı \(_1024_, _1\_204_, _2048_\)
* Noktalı Sayı \(_1.234_, _1\_234.56789_, _123.4e+4_, _1\_230.4e+4_\)
* Yazı \(_"Merhaba Dünya"_, _'Merhaba Dünya'_\)
* Bool \(_doğru_, _yanlış_\)
* Liste \(_\[1,2,3\]_, _\[\]_, _\[:kayıt\_başarılı, 'Kullanıcı Bilgisi'\]_\)
* Sözlük \(_{'ad':'erhan', 'soyad':'barış'}_\)### Döngü
```text
kayıt = 10
toplam = 0
döngü kayıt iken:
gç::satıryaz(kayıt)
kayıt -= 1
toplam += 1
hataayıklama::doğrula(toplam, 10)
hataayıklama::doğrula(kayıt, 0)
``````text
sonsuz:
gç::satıryaz("Sonsuza kadar devam")
```Döngü kontrolü için _devam_, _continue_, _kır_, _break_.
### Sorgulama
```text
a == b ise:
gç::satıryaz('a eşittir b')
veya a == c ise:
gç::satıryaz('a eşittir c')
veya:
gç::satıryaz('a hiçbirine eşit değil')
```## Fonksiyon tanımlama
```text
fonk metod_1(a):
gç::yaz(a)fonk merhaba_dünya:
gç::yaz('Merhaba dünya')fonk metod_1(a):
gç::yaz(a)fonk faktoriyel(faktoriyel_sayısı):
faktoriyel_sayısı==1 veya faktoriyel_sayısı==0 ise:
döndür 1
veya:
döndür faktoriyel_sayısı * faktoriyel(faktoriyel_sayısı - 1)faktoriyel_sonucu = faktoriyel(10)
gç::satıryaz('faktoriyel 10 => ', faktoriyel_sonucu)
```