TALES

TAL Expression Syntax (TALES) – standard definiowania wyrażeń dla języków TAL (Template Attribute Language) i METAL (Macro Extension for TAL). TALES definiuje sześć typów wyrażeń:

  • exists – do sprawdzania czy obiekt istnieje
  • nocall
  • not
  • path
  • python
  • string

Domyślnym typem jest path, dlatego w przypadku braku określenia typu, Zope potraktuje je jako wyrażenie tego właśnie typu. Jeśli istnieje konieczność umieszczenia kilku wyrażeń, to kolejne z nich oddziela się dwukropkiem. Oprócz tego TALES określa również listę słów kluczowych:

  • attrs
  • container – reprezentuje folder, w którym znajduje się plik szablonu ZPT (Zope Page Template)
  • default
  • here
  • modules
  • nothing – reprezentuje zero (0), pusty ciąg znaków lub zmienną niezainicjowaną żadną wartością
  • options
  • repeat
  • request
  • root
  • template – reprezentuje nazwę pliku szablonu ZPT
  • user – nazwa obecnie zalogowanego użytkownika
exists
Wyrażenia typu exists sprawdzają czy dany obiekt istnieje. Obiektem może być plik, zmienna lub własność szablonu ZPT. W przypadku zmiennych oraz własności szablonów, dana cecha nie musi posiadać konkretnej wartości, aby wyrażenie zwróciło TRUE. Wyrażenia tego typu najczęściej używane są w instrukcjach warunkowych tal:condition.
<p tal:condition="exists:template/title">Tekst z obu paragrafów zostanie wyświetlony,</p>
<p tal:condition="exists:template/id">ponieważ każdy szablon posiada własność tytuł oraz id.</p>
nocall
Wyrażenia typu nocall umożliwiają dotarcie do atrybutów danego pliku.
<span tal:define="doc nocall:here/exists.zpt" 
     tal:content="string:${doc/getId} - ${doc/title}">id – tytuł</span>

Zawartość tagu <span> zostanie wypełniona wartościami atrybutów id oraz title pliku exists.zpt znajdującego się w tym samym katalogu co plik szablonu zawierający powyższy wpis. Zarówno w przypadku dodania słowa nocall jak i wtedy gdy go nie ma, sama zmienna doc jest definiowana jako ciąg znaków będących zawartością pliku exists.zpt. Natomiast dzięki nocall istnieje możliwość odczytania wartości atrybutów id oraz title tego pliku. W przypadku plików będących skryptami lub metodami nocall pozwala pobierać wartości zmiennych tamże zdefiniowanych.

not
Wyrażenia not używa się do zaprzeczenia ciągu występującego po nim. Zope sprowadza sekwencję po wyrażeniu not do wartości logicznej TRUE lub FALSE, a następnie ją neguje. Jeżeli nie jest możliwe sprowadzenie wyrażenia do wartości logicznych, to zostaje zwrócone ostrzeżenie o błędzie. Błąd wystąpi również wtedy, gdy po słowie not nie wystąpi żadne wyrażenie. Zasady sprowadzania wyrażeń do wartości logicznych:
  • liczba zero to FALSE
  • liczby dodatnie i ujemne to TRUE
  • pusty ciąg znaków to FALSE
  • nieistniejące pliki, obiekty lub ich właściwości to FALSE
path
Wyrażenia typu path są domyślnym typem wyrażeń instrukcji TAL. Wyrażenia tego typu składają się z ciągów znaków oddzielonych od siebie znakami prawego ukośnika (/). Pierwsze słowo w ścieżce powinno być jednym ze słów kluczowych lub zmienną zdefiniowaną przez użytkownika. Wyrażenia na ścieżce mogą zawierać litery, cyfry, spacje oraz kropki, przecinki, myślniki, znaki podkreślenia i tyldy.