The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

Prty::Section::Object - Abschnitts-Objekt

BASE CLASS

Prty::Object

DESCRIPTION

Ein Objekt der Klasse repräsentiert einen "Abschnitt". Abschnitte werden von Prty::Section::Parser geparst und instanziiert.

Ein Abschnittsobjekt gibt Auskunft über den Inhalt des Abschnitts und dessen "Ort" (Dateiname und Zeilennummer). Das Objekt ist readonly, d.h. die Objekteigenschaften können gelesen aber nicht gesetzt werden.

METHODS

Konstruktor

new() - Konstruktor

Synopsis

    $sec = $class->new($type,$keyValH);
    $sec = $class->new($type,$keyValH,$keyA,$content,$source,$file,$line);

Arguments

$type

Abschnitts-Typ einschließlich Klammern (sofern vorhanden).

$keyValH

Referenz auf Schlüssel/Wert-Hash.

$keyA

Referenz auf Schlüssel-Array.

$content

Inhalt.

$source

Quelltext des Abschnitts.

$file

Name der Datei, die den Abschnitt enthält. Im Falle einer In-Memory-Datei ist der Dateiname "(source)".

$line

Zeilennummer, an der der Abschnitt in der Datei beginnt.

Returns

Referenz auf Abschnitts-Objekt

Description

Instanziiere ein Abschnittsobjekt und liefere eine Referenz auf das Objekt zurück.

Akzessoren

type() - Liefere/Setze Abschnittsbezeichner

Synopsis

    $type = $sec->type;
    $type = $sec->type($type);

Returns

Abschnittsbezeichner (String)

Description

Liefere den Abschnittsbezeichner. Ist Parameter $type angegeben, setze den Abschnittsbezeichner auf diesen Wert.

brackets() - Liefere Klammerung

Synopsis

    $brackets = $sec->brackets;
    $brackets = $sec->brackets($brackets);

Returns

Klammerpaar (String)

Description

Liefere die Klammerung um den Abschnittsbezeichner, sofern vorhanden. Ist der Abschnittsbezeichner nicht geklammert, liefere einen Leerstring. Ist Parameter $brackets angegeben, setze die Klammerung auf diesen Wert.

Details

Die Klamerung um den Abschnitts-Bezeichner ist optional. Sie besteht aus der öffnenden und schließenden Klammer, ist also "[]", "<>" oder "()" oder "{}".

keys() - Liefere die Liste der Schlüssel

Synopsis

    $keyA|@keys = $sec->keys;

Description

Liefere die Liste der Schlüssel. Im Skalarkontext liefere eine Referenz auf die Liste.

keyValHash() - Liefere den Attributhash

Synopsis

    $hash|@arr = $sec->keyValHash;

Returns

Im Sklarkontext liefere eine Referenz auf den Attribut-Hash. Im Arraykontext liefere die Liste der Attribut/Wert-Paare.

content() - Liefere/Setze Inhalt

Synopsis

    $content = $sec->content;
    $content = $sec->content($content);

Returns

Inhalt (String)

contentRef() - Liefere Referenz auf den Inhalt

Synopsis

    $ref = $sec->contentRef;

Returns

Referenz auf Inhalt (String-Referenz)

contentNL() - Liefere Inhalt mit Newline

Synopsis

    $contentN = $sec->contentNL;

Returns

Inhalt mit Newline (String)

source() - Liefere Quelltext

Synopsis

    $source = $sec->source;

Returns

Quelltext (String)

removeEofMarker() - Entferne "# eof" vom Quelltext und vom Content

Synopsis

    $sec->removeEofMarker;

Returns

nichts

deleteSource() - Lösche Quelltext

Synopsis

    $sec->deleteSource;

Returns

nichts

file() - Liefere Dateiname

Synopsis

    $file = $sec->file;

Returns

Dateiname (String)

line() - Liefere Zeilennummer

Synopsis

    $n = $sec->line;

Returns

Zeilennummer (Integer)

fileInfo() - Liefere Dateiname und Zeilennummer in einem Aufruf

Synopsis

    ($file,$line) = $sec->fileInfo;

Returns

Dateiname (String) und Zeilennummer (Integer)

Attribute

get() - Liefere Wert zu Schlüssel

Synopsis

    $val = $sec->get($key);
    @vals = $sec->get(@keys);

Arguments

$key bzw. @keys

Schlüssel, deren Wert geliefert wird.

Returns

Wert (Skalar-Kontext) oder Wertliste (Array-Kontext)

Description

Liefere den Wert zu Schlüssel $key bzw. die liste der Werte zu den Schlüsseln @keys. Beginnt der $key mit einem Großbuchstaben, ist es ein fataler Fehler, wenn zu dem Schlüssel mehrere Werte existieren. Solche Schlüssel müssen mit $obj->getArray() abgefragt werden.

getArray() - Liefere Wertliste zu Schlüssel

Synopsis

    $arr|@arr = $sec->getArray($key);

Arguments

$key

Schlüssel dessen Wertliste geliefert wird.

Returns

Wert bzw. Werte

Description

Liefere die Wertliste von Schlüssel $key.

getBool() - Liefere boolschen Wert zu Schlüssel

Synopsis

    $bool = $sec->getBool($key);
    $bool = $sec->getBool($key,$default);

Arguments

$key

Schlüssel, dessen Wert geliefert wird.

$default

Defaultwert, wenn Attribut nicht gesetzt

Returns

Wert (Skalar)

Description

Liefere boolschen Wert zu Schlüssel $key.

getMandatory() - Liefere Wert eines Pflichtattributs

Synopsis

    $val = $sec->getMandatory($key);

Arguments

$key

Schlüssel, dessen Wert geliefert wird.

Returns

Wert (Skalar)

Description

Wie $sec->get(), nur dass ein Wert existieren muss, sonst wird eine Exception geworfen.

getRef() - Liefere Referenz auf Schlüsselwert

Synopsis

    $ref = $sec->getRef($key);

try() - Werte abfragen ohne Exception

Synopsis

    $val = $sec->try($key);
    @vals = $sec->try(@keys);

Description

Wie get(), nur dass im Falle eines unerlaubten Schlüssels keine Exception geworfen, sondern undef geliefert wird.

memoize() - Ermittele Wert und cache ihn auf Attribut

Synopsis

    $val = $sec->memoize($key,$sub);

Description

Die Methode liefert den Wert des Attributs $key. Ist kein Wert definiert (Wert ist undef), wird die Methode $sec->$sub($key) gerufen, der Wert berechnet und auf dem Attribut $key gespeichert. Weitere Aufrufe liefern diesen Wert, ohne dass er neu berechnet wird.

Die Methode ist nützlich, um in Objektmethoden eingebettet zu werden, die einen berechneten Wert liefern, der nicht immer wieder neu gerechnet werden soll.

Example

    sub name {
        return shift->memoize('name',sub {
            my ($self,$key) = @_;
            my $name = $self->get(ucfirst $key);
            $name =~ s/^\W+//;
            $name =~ s|\W+|/|g;
            return $name;
        });
    }

memoizeWeaken() - Ermittele schwache Referenz

Synopsis

    $val = $sec->memoizeWeaken($key,$sub);

Description

Die Methode ist identisch zu $sec->memoize(), nur dass eine Referenz ermittelt und automatisch zu einer schwachen Referenz gemacht wird.

set() - Setze Schlüssel auf Wert

Synopsis

    $sec->set(@keyVal);

Arguments

@keyVal

Schlüssel/Wert-Paare, die gesetzt werden.

Returns

nichts

setDefault() - Setze Defaultwert

Synopsis

    $sec->setDefault(@keyVal);

Arguments

@keyVal

Liste der Schlüssel/Wert-Paare.

Returns

nichts

Description

Setze Schlüssel ohne Wert, d.h. wenn der Wert ein Leerstring ist, setze ihn auf den angegebenen Defaultwert.

Example

    $sec->setDefault(
        Width=>1000,
        EntityMenuWidth=>345,
        BorderWidth=>1,
        PackageMenuHeight=>34,
    );

push() - Füge Element zu Arraykomponente hinzu

Synopsis

    $sec->push($key,$val);

Arguments

$key

Arraykomponente.

$val

Wert, der zum Array am Ende hinzugefügt wird.

Description

Füge Wert $val zur Arraykomponente $key hinzu. Die Methode liefert keinen Wert zurück.

weaken() - Erzeuge schwache Referenz

Synopsis

    $ref = $sec->weaken($key);
    $ref = $sec->weaken($key=>$ref);

Description

Mache die Referenz von Schlüssel $key zu einer schwachen Referenz und liefere sie zurück. Ist eine Referenz $ref als Parameter angegeben, setze die Referenz zuvor.

validate() - Prüfe und ergänze Attribute

Synopsis

    $sec->validate($contentAllowed,\@keys);

Arguments

$contentAllowed

Wenn falsch, erlaubt der Abschnitt keinen Content (außer "# eof" als Dateiende-Markierung).

@keys

Liste der zulässigen Abschnittsattribute

Returns

Nichts

Description

Die Methode finalisiert das Abschnittsobjekt in folgender Weise:

  • Sie prüft, dass wenn kein Content erlaubt ist, keiner existiert.

  • Sie prüft, dass nur Schlüssel im Objekt vorkommen, die in @keys vorkommen. Kommt ein anderer Schlüssel im Objekt vor, wird eine Exception geworfen.

  • Sie fügt Schlüssel aus @keys zum Objekt hinzu, die das Objekt nicht hat.

lockKeys() - Locke die Keys des Attribut-Hash

Synopsis

    $sec->lockKeys;

Automatische Akzessor-Methoden

AUTOLOAD() - Erzeuge Akzessor-Methode

Synopsis

    $val = $this->AUTOLOAD;
    $val = $this->AUTOLOAD($val);

Description

Erzeuge beim ersten Aufruf eine Akzessor-Methode für einen Schlüssel des Schlüssel/Wert-Hashs und führe den betreffenden Methodenaufruf durch.

VERSION

1.083

AUTHOR

Frank Seitz, http://fseitz.de/

COPYRIGHT

Copyright (C) 2016 Frank Seitz

LICENSE

This code is free software; you can redistribute it and/or modify it under the same terms as Perl itself.