YAML
Enes Gerem
Posted on June 28, 2021
YAML yazılım dünyasında artık her yerde karşımıza çıkan bir dosya formatı ve configürasyon dosyası alternatifi haline geldi. Fakat nedir bu YAML?
YAML (YAML Ain't Markup Language) dil bağımsız bir veri değişim formatıdır. Herhangi bir programlama dili ile oluşturulan nesneler, YAML formatında kolaylıkla temsil edilebilmektedir. YAML geniş veri tipi desteği sayesinde tüm diller arasında ortak olarak kullanılabilir olmakla birlikte, ayrıca insan gözüyle bakıldığında kolay okunabilir bir yapısı mevcuttur.
YAML, konfigürasyon dosyaları için ve verilerin depolandığı veya iletildiği uygulamalarda yaygın olarak kullanılır. XML(Extensible Markup Language)'in kullanıldığı uygulamaların çoğunu hedefler ancak SGML(Standard Generalized Markup Language)'den kasıtlı olarak farklı olan minimal bir sözdizimine sahiptir.
YAML Syntaxı
YAML Nested yapısını belirtmek için Python tarzı girintiyi, listeler için köşeli parantezleri [...] ve mapler için süslü
parantezleri {...} barındıran daha kompakt bir biçim kullanır.
Bazı basit kurallar;
- Yapıyı belirtmek için boşluk girintisi kullanılır; ancak, bu girintinin parçası olarak sekme karakterlerine izin verilmez.
- Yorumlar "#" ile başlar, bir satırda herhangi bir yerden başlayabilir ve satırın sonuna kadar devam edebilir.
# Bu bir yorum satırıdır.
- Liste elemanları, her satırda bir eleman olacak şekilde "-" ile veya köşeli parantezlerin içine elemanları virgülle ayırarak gösterilir.
# Listelerin tanımlanma şekilleri
- A
- B
- C
[ A,B,C ]
- Dictionary yapısı "key:value" formunda her satırda bir eleman olacak şekilde listelenebilir.
# Dictionary
enes:
name: Enes Gerem
age: 23
- Dictionary listesi aşağıdaki gibi belirtilebilir.
# Dictionary listesi
- enes:
name: Enes Gerem
age: 23
- emre:
name: Emre Basar
age: 22
Alternatif olarak dictionary yapısı süslü parantezlerle de belirtilebilir.
"|" ve ">" kullanarak, tanımlar birden çok satırda belirtilebilir. Satır başı karakterini de almak istediğimiz de "|",
tek bir satır yazacaksak ve sadece okunabilirliği arttırmak istiyorsak ">" kullanabiliriz.
include_newlines: |
bu String tam olarak
bu sekilde
gozukecektir
fold_newlines: >
bu değer aslinda
sadece bir satiri
ifade eder
İki nokta'dan ":" sonra bir boşluk varsa bu bir dictionaryi temsil eder. Eğer iki noktayı value kısmında kullanmak istiyorsak boşluk olmadan, escape karakteriyle ya da tırnak içinde kullanmamız gerekir.
Değişkenler "{var}" formatında belirtilebilir.
foo: "{variable}"
Aşağıda YAML formatında hazırlanmış YAML formatı için derlenen referans dosyası incelenebilir.
Kaynak: yaml.org
%YAML 1.1 # Reference card
---
Collection indicators:
'? ': Key indicator.
': ': Value indicator.
'- ': Nested series entry indicator.
', ': Separate in-line branch entries.
'[]': Surround in-line series branch.
'{}': Surround in-line keyed branch.
Scalar indicators:
'''': Surround in-line unescaped scalar ('' escaped ').
'"': Surround in-line escaped scalar (see escape codes below).
'|': Block scalar indicator.
'>': Folded scalar indicator.
'-': Strip chomp modifier ('|-' or '>-').
'+': Keep chomp modifier ('|+' or '>+').
1-9: Explicit indentation modifier ('|1' or '>2').
# Modifiers can be combined ('|2-', '>+1').
Alias indicators:
'&': Anchor property.
'*': Alias indicator.
Tag property: # Usually unspecified.
none: Unspecified tag (automatically resolved by application).
'!': Non-specific tag (by default, "!!map"/"!!seq"/"!!str").
'!foo': Primary (by convention, means a local "!foo" tag).
'!!foo': Secondary (by convention, means "tag:yaml.org,2002:foo").
'!h!foo': Requires "%TAG !h! <prefix>" (and then means "<prefix>foo").
'!<foo>': Verbatim tag (always means "foo").
Document indicators:
'%': Directive indicator.
'---': Document header.
'...': Document terminator.
Misc indicators:
' #': Throwaway comment indicator.
'`@': Both reserved for future use.
Special keys:
'=': Default "value" mapping key.
'<<': Merge keys from another mapping.
Core types: # Default automatic tags.
'!!map': { Hash table, dictionary, mapping }
'!!seq': { List, array, tuple, vector, sequence }
'!!str': Unicode string
More types:
'!!set': { cherries, plums, apples }
'!!omap': [ one: 1, two: 2 ]
Language Independent Scalar types:
{ ~, null }: Null (no value).
[ 1234, 0x4D2, 02333 ]: [ Decimal int, Hexadecimal int, Octal int ]
[ 1_230.15, 12.3015e+02 ]: [ Fixed float, Exponential float ]
[ .inf, -.Inf, .NAN ]: [ Infinity (float), Negative, Not a number ]
{ Y, true, Yes, ON }: Boolean true
{ n, FALSE, No, off }: Boolean false
? !!binary >
R0lG...BADS=
: >-
Base 64 binary value.
Escape codes:
Numeric: { "\x12": 8-bit, "\u1234": 16-bit, "\U00102030": 32-bit }
Protective: { "\\": '\', "\"": '"', "\ ": ' ', "\<TAB>": TAB }
C: { "\0": NUL, "\a": BEL, "\b": BS, "\f": FF, "\n": LF, "\r": CR,
"\t": TAB, "\v": VTAB }
Additional: { "\e": ESC, "\_": NBSP, "\N": NEL, "\L": LS, "\P": PS }
...
YAML artık birçok framework'ün tercih ettiği configuration formatı haline geldi. En popüler front-end Web framework'ü
React'te ve mobil framework'ü Flutter'da bu yapıyı görmek mümkün.
Örnek olması açısından aşağıda Flutter projelerimden birinin "pubspec.yaml" configuration dosyası incelenebilir.
name: receipt_scanner
description: Receipt scanner app
# The following defines the version and build number for your application.
# A version number is three numbers separated by dots, like 1.2.43
# followed by an optional build number separated by a +.
# Both the version and the builder number may be overridden in flutter
# build by specifying --build-name and --build-number, respectively.
# In Android, build-name is used as versionName while build-number used as versionCode.
# Read more about Android versioning at https://developer.android.com/studio/publish/versioning
# In iOS, build-name is used as CFBundleShortVersionString while build-number used as CFBundleVersion.
# Read more about iOS versioning at
# https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html
version: 1.0.0+1
environment:
sdk: ">=2.1.0 <3.0.0"
dependencies:
flutter:
sdk: flutter
cupertino_icons: ^0.1.2
firebase_ml_vision:
image_picker:
image_cropper:
path_provider: ^1.6.11
mailer: ^3.0.4
excel: ^1.1.5
camera_camera: ^1.0.34+1
firebase_auth: ^0.16.1
cloud_firestore: ^0.13.7
provider: ^3.1.0
flutter_spinkit: ^4.1.2+1
http: ^0.12.0+3
sqflite: ^1.3.1
google_sign_in: ^4.5.1
camera: ^0.5.8+5
path: ^1.6.4
auto_size_text: ^2.1.0
flushbar: ^1.5.0
rxdart: ^0.24.1
dev_dependencies:
flutter_test:
sdk: flutter
flutter_launcher_icons: "^0.7.3"
flutter_icons:
android: true
ios: true
image_path: "assets/icon/voucher_logo.png"
# The following section is specific to Flutter.
flutter:
# The following line ensures that the Material Icons font is
# included with your application, so that you can use the icons in
# the material Icons class.
uses-material-design: true
assets:
- assets/image/google.png
- assets/image/bg.png
- assets/files/example.xlsx
- assets/files/temp.xlsx
- assets/background/top.png
- assets/background/right.png
- assets/background/bttm.png
- assets/icon/google.png
- assets/icon/facebook.png
- assets/icon/apple.png
- assets/icon/twitter.png
- assets/icon/receipt_logo.png
- assets/icon/splash_screen.png
- assets/icon/profile.png
- assets/icon/data.png
- assets/icon/home.png
- assets/icon/homeon.png
- assets/icon/dataon.png
- assets/icon/profileon.png
- assets/icon/user.png
- assets/icon/lock.png
fonts:
- family: Poppins
fonts:
- asset: fonts/Poppins/Poppins-Black.ttf
weight: 900
- asset: fonts/Poppins/Poppins-Bold.ttf
weight: 700
- asset: fonts/Poppins/Poppins-ExtraBold.ttf
weight: 800
- asset: fonts/Poppins/Poppins-Light.ttf
weight: 400
- asset: fonts/Poppins/Poppins-Medium.ttf
weight: 600
- asset: fonts/Poppins/Poppins-Regular.ttf
weight: 500
- asset: fonts/Poppins/Poppins-SemiBold.ttf
weight: 700
- family: Spartan
fonts:
- asset: fonts/Spartan-VariableFont_wght.ttf
Posted on June 28, 2021
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.