mirror of
https://github.com/adambard/learnxinyminutes-docs.git
synced 2025-01-14 21:25:58 +00:00
230 lines
6.6 KiB
Markdown
230 lines
6.6 KiB
Markdown
---
|
|
contributors:
|
|
- ["Alois de Gouvello", "https://github.com/aloisdg"]
|
|
translators:
|
|
- ["Adaías Magdiel", "https://adaiasmagdiel.com/"]
|
|
---
|
|
|
|
TOML significa Tom's Obvious, Minimal Language. É uma linguagem de serialização de dados projetada para ser um formato de arquivo de configuração mínimo que é fácil de ler devido à semântica óbvia.
|
|
|
|
É uma alternativa ao YAML e JSON. Tem como objetivo ser mais amigável para humanos do que JSON e mais simples que YAML. TOML é projetado para mapear de forma inequívoca para uma tabela de hash e deve ser fácil de converter em estruturas de dados em uma ampla variedade de linguagens.
|
|
|
|
Cuidado, a especificação do TOML ainda passa por muitas mudanças. Até que seja marcado como 1.0, você deve assumir que é instável e agir de acordo. Este documento segue o TOML v0.4.0.
|
|
|
|
```toml
|
|
# Comentários em TOML são feitos desta forma.
|
|
|
|
###################
|
|
# TIPOS ESCALARES #
|
|
###################
|
|
|
|
# Nosso objeto raiz (que continuará por todo o documento) será um mapa,
|
|
# que é equivalente a um dicionário, hash ou objeto em outras linguagens.
|
|
|
|
# A chave, o sinal de igual e o valor precisam estar na mesma linha
|
|
# (embora alguns valores possam ser quebrados em várias linhas).
|
|
chave = "valor"
|
|
string = "Olá"
|
|
number = 42
|
|
float = 3.14
|
|
boolean = true
|
|
dateTime = 2002-07-16T20:32:00-03:00
|
|
scientificNotation = 1e+12
|
|
"chaves podem estar entre aspas" = true # Tanto " quanto ' são aceitáveis
|
|
"chaves podem conter" = "letras, números, underscores e hífens"
|
|
|
|
# Uma chave não pode ser vazia, mas uma chave vazia entre aspas é permitido
|
|
"" = "blank" # VÁLIDO mas não é recomendado
|
|
'' = 'blank' # VÁLIDO mas não é recomendado
|
|
|
|
##########
|
|
# String #
|
|
##########
|
|
|
|
# Todas as strings precisam ter apenas caracteres UTF-8 válidos.
|
|
# Podemos escapar caracteres e alguns deles têm uma sequência de escape compacta.
|
|
# Por exemplo: \t adiciona uma tabulação. Leia a spec para conhecer todos.
|
|
basicString = "São cercadas por aspas. \"Sou digno de citação\". Nome\tJosé."
|
|
|
|
multiLineString = """
|
|
são cercadas por três aspas
|
|
em cada lado e permitem novas linhas."""
|
|
|
|
literalString = 'são cercadas por aspas simples. Escape de caracteres não é permitido.'
|
|
|
|
multiLineString = '''
|
|
são cercadas por três aspas simples em cada lado
|
|
e permitem novas linhas. Escape de caracteres também não é permitido.
|
|
A primeira quebra de linha é removida em strings brutas
|
|
Todo outro espaço em branco
|
|
é preservado. #! foi preservado?
|
|
'''
|
|
|
|
# Para dados binários é recomendado que você use Base64, outra codificação ASCII ou UTF8.
|
|
# A manipulação dessa codificação será específico da aplicação.
|
|
|
|
############
|
|
# Inteiros #
|
|
############
|
|
|
|
## Inteiros podem começar com um +, um -, ou nada.
|
|
## Zeros à frente não são permitidos.
|
|
## Formatos em hexadecimal, octal e binário são permitidos.
|
|
## Não são permitidos valores que não podem ser expressados como uma série de dígitos.
|
|
int1 = +42
|
|
int2 = 0
|
|
int3 = -21
|
|
int4 = 0xcafebabe
|
|
int5 = 0o755
|
|
int6 = 0b11011100
|
|
integerRange = 64
|
|
|
|
## Você pode usar underscores para melhorar a legibilidade.
|
|
## Cada underscore precisa estar entre, pelo menos, um dígito.
|
|
int7 = 5_349_221
|
|
int8 = 1_2_3_4_5 # VÁLIDO, mas não é recomendado
|
|
|
|
#########
|
|
# Float #
|
|
#########
|
|
|
|
# Floats são inteiros seguidos por uma fração e/ou de um expoente.
|
|
flt1 = 3.1415
|
|
flt2 = -5e6
|
|
flt3 = 6.626E-34
|
|
|
|
#############
|
|
# Booleanos #
|
|
#############
|
|
|
|
bool1 = true
|
|
bool2 = false
|
|
booleanosPrecisamEstarEmMinusculo = true
|
|
|
|
############
|
|
# Datetime #
|
|
############
|
|
|
|
date1 = 1979-05-27T07:32:00Z # Tempo UTC, seguindo especificação RFC 3339/ISO 8601
|
|
date2 = 1979-05-26T15:32:00+08:00 # com um deslocamento segundo a RFC 3339/ISO 8601
|
|
date3 = 1979-05-27T07:32:00 # sem deslocamento
|
|
date4 = 1979-05-27 # sem as horas e sem deslocamento
|
|
|
|
####################
|
|
# TIPOS DE COLEÇÃO #
|
|
####################
|
|
|
|
#########
|
|
# Array #
|
|
#########
|
|
|
|
array1 = [ 1, 2, 3 ]
|
|
array2 = [ "Vírgulas", "são", "delimitadores" ]
|
|
array3 = [ "Não misture", "tipos", "diferentes" ]
|
|
array4 = [ [ 1.2, 2.4 ], ["todas as", 'strings', """são do mesmo""", '''tipo'''] ]
|
|
array5 = [
|
|
"Espaços em branco", "são", "ignorados"
|
|
]
|
|
|
|
##########
|
|
# Tabela #
|
|
##########
|
|
|
|
# Tabelas (ou tabelas de hash, ou dicionários) é uma coleção de pares chave/valor.
|
|
# Eles aparecem entre colchetes em uma linha separada.
|
|
# Tabelas vazias são permitidas e simplesmente não possuem chave/valor associado.
|
|
[tabela]
|
|
|
|
# Abaixo disso, e até a próxima tabela ou final do arquivo, estão as chaves/valores dessa tabela.
|
|
# Os pares de chave/valor dentro das tabelas não têm garantia de estar em nenhuma ordem específica.
|
|
[table-1]
|
|
chave1 = "algum texto"
|
|
chave2 = 123
|
|
|
|
[table-2]
|
|
chave1 = "outro texto"
|
|
chave2 = 456
|
|
|
|
# Pontos são proibidos em chaves simples porque são usados para indicar tabelas aninhadas.
|
|
# As regras de nomenclatura para cada parte separada por ponto são as mesmas que para chaves.
|
|
[dog."tater.man"]
|
|
type = "pug"
|
|
|
|
# Na terra do JSON, você teria a seguinte estrutura:
|
|
# { "dog": { "tater.man": { "type": "pug" } } }
|
|
|
|
# Espaços em branco em torno das partes separadas por pontos são ignorados, de qualquer forma,
|
|
# é sempre recomendado não utilizar espaços em branco desnecessários.
|
|
[a.b.c] # isso é o recomendado
|
|
[ d.e.f ] # mesmo que [d.e.f]
|
|
[ j . "ʞ" . 'l' ] # mesmo que [j."ʞ".'l']
|
|
|
|
# Você não precisa especificar todas as super-tabelas se não quiser. TOML sabe
|
|
# como lidar com isso para você.
|
|
# [x] você
|
|
# [x.y] não precisa
|
|
# [x.y.z] disso
|
|
[x.y.z.w] # para isso funcionar
|
|
|
|
# Mesmo que uma super-tabela não tenha sido definida diretamente e não tenha definido uma
|
|
# chave específica, ainda é possível escrever nela.
|
|
[a.b]
|
|
c = 1
|
|
|
|
[a]
|
|
d = 2
|
|
|
|
# Irá gerar o seguinte JSON:
|
|
# { "a": {"b": {"c": 1}, "d": 2 } }
|
|
|
|
# Você não pode definir uma chave ou tabela mais de uma vez. É inválido fazer isso.
|
|
|
|
# NÃO FAÇA ISSO
|
|
[a]
|
|
b = 1
|
|
|
|
[a]
|
|
c = 2
|
|
|
|
# NEM MESMO ISSO
|
|
[a]
|
|
b = 1
|
|
|
|
[a.b]
|
|
c = 2
|
|
|
|
# O nome de todas as tabelas não pode ser vazio.
|
|
[] # INVÁLIDO
|
|
[a.] # INVÁLIDO
|
|
[a..b] # INVÁLIDO
|
|
[.b] # INVÁLIDO
|
|
[.] # INVÁLIDO
|
|
|
|
####################
|
|
# Tabelas em linha #
|
|
####################
|
|
|
|
tabelasEmLinha = { sãoFechadasCom = "{ e }", precisamEstarEmUmaLinha = true }
|
|
ponto = { x = 1, y = 2 }
|
|
|
|
####################
|
|
# Array de Tabelas #
|
|
####################
|
|
|
|
# Um array de tabelas pode ser expresso usando um nome de tabela entre colchetes duplos.
|
|
# Cada tabela com o mesmo nome entre colchetes duplos será um item no array.
|
|
# As tabelas são inseridas na ordem em que são encontradas.
|
|
|
|
[[produtos]]
|
|
nome = "array de tabelas"
|
|
sku = 738594937
|
|
tabelasVaziasSaoPermitidas = true
|
|
|
|
[[produtos]]
|
|
|
|
[[produtos]]
|
|
nome = "Unhas"
|
|
sku = 284758393
|
|
color = "cinza"
|
|
```
|