Türkçe Yazılım Konatı
AnabetDiller & DahasıSözlüklerKimiz?
  • KPD: Karamel Programlama Dili
  • ⚙️İşlevler
    • Dizme İşlevleri
      • getir(sıra)
      • uzunluk()
      • ekle(nesne)
      • temizle()
      • arayaekle(sıra, nesne)
      • pop()
      • sil(sıra)
    • Sayı İşlevleri
      • onaltılık()
      • yuvarla()
      • tavan()
      • taban()
      • tamsayı()
      • kesir()
    • Sözlük İşlevleri
      • SÖZLÜK[].uzunluk()
      • SÖZLÜK[].getir(açar)
      • SÖZLÜK[].ekle(açar, değer)
      • SÖZLÜK[].güncelle(açar, değer)
      • SÖZLÜK[].içeriyormu(açar)
      • SÖZLÜK[].temizle()
      • SÖZLÜK[].sil(açar)
      • SÖZLÜK[].anahtarlar()
    • Yazı İşlevleri
      • SaydamBoşluk***
      • YAZI.parçagetir(buradan, burayadek)
      • YAZI.değiştir(ESKİ_DEĞER, YENİ_DEĞER)
      • YAZI.harfleriküçült()
      • YAZI.harfleribüyült()
      • YAZI.uzunluk()
      • YAZI.içeriyormu(ARANAN_DEĞER)
      • YAZI.satırlar()
      • YAZI.parçala(DEĞER)
      • YAZI.kırp()
      • YAZI.sonukırp()
      • YAZI.başıkırp()
  • Belgeler
    • Kılavuzlar
    • Hakkında
      • SSS
      • Takımlar
  • Sözlükler
    • Genel Sözlük
    • Bilişim Terimleri Sözlüğü
  • CHANGES
  • Contributor Covenant Code of Conduct
  • Contributing
Powered by GitBook
LogoLogo

Biz

  • Anabet

Buradayız

  • Discord
  • Instagram
  • Facebook

Türkçe Yazılım Konatı

On this page
  • Welcome
  • Prerequisites
  • Requesting Features
  • Reporting Issues
  • Fixing Issues (PRs)
  • In a nutshell
  • Keep in Mind
  • Build and Test

Contributing

PreviousContributor Covenant Code of Conduct

Last updated 4 years ago

Contents

Welcome

Hello and welcome to Karamel. We are making Turkish programming language, but you probably knew that already. If you are considering contributing to Karamel this document will be hopefully be a helpful resource.

Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.

You do not have to be a programmer. There are many ways to contribute::

  • Hang out on our and help answers questions as they come up

  • Report or join the existing discussion on open issues

  • Submit pull requests to resolve issues

  • Improve our documentation to better explain all the things to all the peoples

Prerequisites

  • To help answer questions on issues or contribute on Discord you need only be friendly.

  • To work on the core language engine you'll need to know Rust-Lang.

  • To work on documentation you need to be ready and willing to document things.

Requesting Features

Feature requests are always welcome. If the feature doesn't belong in the core library then we're always happy to suggest how you might go about developing a plug-in.

If you're thinking of contributing a feature first open an issue to discuss whether the feature belongs in core vs a plug-in. Often this is a great way to get implementation tips or links to prior discussions on the topic often with additional context, etc.

Reporting Issues

Fixing Issues (PRs)

In a nutshell

  1. Fork this project on GitHub.

  2. Clone it locally git clone git@github.com:username/Karamel.git.

  3. Create a work branch (git checkout -b my-branch).

  4. Commit your changes (git commit -m 'my changes').

  5. Push the branch (git push origin my-branch).

  6. Open a Pull Request from your fork back to this repository.

Keep in Mind

Please open a new issue before your PR (or join the discussion on the existing issue), so we can explore and discuss the topic at hand. Your time is important, and we need to be sure it's well-spent.

Before you start coding, keep these tips in mind:

  • You should usually add markup tests (ie. whenever you've made a significant grammar change or fixed a bug). Simply adding keywords can be an exception to this rule.

  • Change only what needs to be changed; don't re-lint or rewrite whole files when fixing small bugs

  • Linting or major re-organization needs a dedicated commit

Build and Test

When contributing a PR (that doesn't make any specific changes to browser features) it's usually sufficient to build and test only the Node.js build. Our CI process will guarantee that the browser build is still green.

Building the Karamel:

cargo build --release

Testing the Karamel:

cargo test --all

If you find a bug or think of an improvement, feel free to .

If you feel comfortable with the , you can grab any issue marked . Or feel free to jump in with thoughts or comments on any of the more complex issues.

If you're new to contributing to open-source, have a look at . It explains the general process of GitHub collaboration.

Karamel is developed in Rust-Lang, so you'll need the usual suspects: , git, etc. You'll likely start by forking the repository on GitHub and then cloning it locally.

After you make your changes, we have some housekeeping tasks for you - like updating the . The PR template will be your guide.

open an issue
prerequisites
"good first issue"
this GitHub Guide
Rust-Lang
Build and Test
changelog
Welcome
Prerequisites
Requesting Features
Language Requests
Reporting Issues
Fixing Issues (PRs)
In a nutshell
Build and Test
Discord
new issues or bugs
help welcome issues
open issues
good first issue