![]() |
Re: himXML (gesprochen himix ML)
ich bin zwar dabei eine neue Hilfe zu basteln, aber das dauert noch ein bissl
aktuell ist aber einiges in Form einer Inline-Hilfe direkt in den Dateien z.B. schau hierfür mal in die Unit himXML.pas (bzw. himXMLi.pas der alten Version) und klappe dort ganz oben die Region "Help" auf (der zweite ganz lange Kommentar) ... Delphi 2009 sollte die Regionen ja standardmäßig zugeklappt haben. dort gibt es zu einigen Dingen schon eine kleine Erklärung z.B.
Code:
// Count CountNF -
// Node NodeNF (1) - // NodeU NodeUNF (1) see .Node but node always not created, ... // NodeList NodeListNF (1) -
Code:
schwer wird es nur, da ich mein "System" versuche auszulagern, so daß es mal möglich sein sollte auch sowas wie XPath nachzurüsten, bzw. mein System durch ein Alternatives oder Userdefinierte auszutauschen.
// (1) node names allowed paths, attributes and an index
// "{\}{.\}{..\}{node...\}{nodeName}{>attr=value{>attr=value{...}}}{[index]}" // // Node['\..\node'] Owner.RootNode.Parent.Node['node'] aka ... // Node['\node'] Owner.RootNode.Node['node'] or {first ... // Node['.\node'] {Self.}Node['node'] // Node['..\node'] Parent.Node['node'] // Node['node1\node2'] Node['node1'].Node['node2'] // Node['node>attr=value'] Node['node'] with Attributes['attr']='value' // Node['node>attr=value>attr2=value2'] Node['node'] with Attributes['attr']='value' and ... // Node['node[3]'] NodeList['node'][3] // Node['[3]'] Node[3] // Node['>attr=value'] first of Node.Nodes with Attributes['attr']='value' // Node['>attr=value[3]'] 3rd of Node.Nodes with Attributes['attr']='value' // Node['*:node'] ignore namespace // Node['name:*'] first/all nodes with this namespace // // Node['node1[2]\node2>attr=value[3]'] NodeList['node1'][2].NodeList['node2'][3] with ... // // (2) attribut names allowed paths - see at (1) // "{nodePath}\attributeName" // // Attribute['node\attr'] Node['node'].Attribute['attr'] also im Grunde sollte Node['tag1>attr=value'] funktionieren. :gruebel: |
Re: himXML (gesprochen himix ML)
Danke, das hilft mir sehr weiter. Ich hatte zwar schon in die Dateien mal reingeschaut, auch die einzelnen Regions gesehen (wusste gar nicht, dass es sowas gibt :P), aber nicht wirklich etwas zu diesen Bezeichnungen gefunden. Hab vielleicht nicht genau genug gesucht ^^
Zu dem "tag1>attr=value" werd ich nochmal genauer schauen, warum das nicht funktioniert hatte. Diese "Abkürzungen" find ich übrigens sehr gut gelungen, da kommt man auch in etwas größeren Dokumenten relativ schnell an den eigentlichen Tag, den man lesen möchte :thumb: (Gerade wenn man nicht alle Informationen benötigt) |
Re: himXML (gesprochen himix ML)
Die Regionen sind schon 'ne praktische Sache, vorallem da man so auch Blöcke ausgeblendet bekommt, welche einem grade nicht "wichtig" sind und man so schneller und übersichtlicher an bestimmete Stellen kommt.
Nja, ![]() Abgesehn davon, daß hier auch schneller über Hashtabellen gesucht wird ... hab die Nodes und Attribute extra dafür optimiert. :angel: falls du Regionen auch mal selber nutzen willst...
Delphi-Quellcode:
dieses {$IF X}...{$IFEND} kannst'e ignorieren, das hab ich nur drinnen, weil ältere Delphis keine Regionen kennen
{$IF X}{$REGION 'help'}{$IFEND}
... {$IF X}{$ENDREGION}{$IFEND}
Delphi-Quellcode:
und beim Zusammenklappen wird dann nur noch der Text angezeigt ... ist praktisch das Selbe, was man mit Funktionen und Typen (Records/Klassen) machen kann, nur halt für größere Bereiche/Regionen
{$REGION 'beliebiger Text'}
... {$ENDREGION} |
Re: himXML (gesprochen himix ML)
Danke für die Antwort, wenn es sich das nächste Mal anbietet, weiß ich jetzt, wie ich etwas mehr Übersicht hineinbringen kann :mrgreen:
Ich habe jetzt auch die Zeit gefunden, das Problem mit dem Zugriff mit Attribut-Wert genauer zu untersuchen, und nun funktioniert das auch. Da muss mir wohl beim letzten Mal ein Fehler unterlaufen sein (Tippfehler oder ähnliches), dein Code funktioniert also wie er soll :wink: |
Re: himXML (gesprochen himix ML)
Hallo himitsu!
Ich versuche gerade himXML in einem anderen Projekt einzusetzen. Dabei stellt sich mir die Frage, wie komme ich an die Attribute eines Nodes.
Delphi-Quellcode:
Die Datei sieht dabei so aus:
procedure TTag.LoadFromFile(const AFilename: string);
var f : TXMLFile; begin Parent := nil; // öffnen bla bla f := TXMLFile.Create; try f.LoadFromFile(AFilename); LoadFromNode(f['virtualroot\root']); finally f.Free; end; end; procedure TTag.LoadFromNode(const AXMLNode: TXMLNode); var na : string; i, ty: Integer; t : TEntry; nds : TXMLNodeArray; begin Name := AXMLNode.Node['name'].Text; nds := AXMLNode.NodeList['files\file']; for i := 0 to High(nds) do begin ty := nds[i]['@type'].Text; // Directory Node if (ty and 1) = 1 then begin t := TTag.Create; FChilds.Add(t); t.Parent := Self; TTag(t).LoadFromNode(nds[i]); end else begin t := TEntry.Create; FFiles.Add(t); t.Name := nds[i]['name'].Text; end; t.Hidden := (ty and 2) = 2; end; end;
XML-Code:
Wenn ich nun die Zeile 28 ausführe um den Type des Nodes "taxs\virtualroot\root\files\file[0]" zu kommen.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<taxs> <virtualroot> <root> <name>Root</name> <files> <!-- Filecontainer with "filetype" Bit Meaning (if set) 1 Directory 2 Hidden --> <file type=1> <name>Sub</name> <files> <file type=3> <name>HiddenSub</name> </file> <file type=1> <name>Sub</name> <files> <file type=2> <name>HiddenFile</name> <original>C:...</original> </file> </files> </file> </files> </file> <file type=0> <name>Filetest</name> <original>C:...</original> </file> </files> </root> </virtualroot> </taxs> Zitat:
xZise |
Re: himXML (gesprochen himix ML)
Im Prinzip einfach dadurch, daß man auf die Eigenschaft .Attributes den jeweiligen Nodes zugreift :angel:
Delphi-Quellcode:
ty := nds[i].Attributes['type'];
|
Re: himXML (gesprochen himix ML)
Aha. Kann man das nicht irgendwie verkürzt schreiben?
Und jetzt habe ich ein ganz anderes komisches Problem. Und zwar wenn "LoadFromNode" gerade den "HiddenSub" Node abarbeitet, dann ist nds zwar "leer" (im Debugger steht: nds = ()), aber er geht trotzdem in die Schleife und scheitert dann grandios dabei das Attribut des ersten nicht vorhandenen Nodes auszulesen. MfG xZise |
Re: himXML (gesprochen himix ML)
Liste der Anhänge anzeigen (Anzahl: 2)
Zitat:
Zitat:
PS: was das Debuggen angeht ... In der neuen Version ist dieses in meinem Projekt standardmäßig abgeschaltet. (noch nicht hochgeladen) Und in der Beta läßt es sich über die Projektoptionen abstellen, dort einfach in den Bedingungen "hxNotDebugable" einfügen > D2009 > Projektoptionen > Delphi-Compiler > Bedingungen Dann läßt sich das eigene Programm einfacher debuggen, da nicht ständig im Einzelschritt in meine Units gewechselt wird. :angel: |
Re: himXML (gesprochen himix ML)
Liste der Anhänge anzeigen (Anzahl: 2)
Hab hier mal 'nen noch ungetesteten Code zum Speichern und Laden eines TTreeView.
Gespeichert wird natürlich der .Text und die ganzen Subnodes ... also die ganze Baum-Struktur des Trees und beim Rest kann man entschieden werden, was man speichern/laden will. Da wären die ganzen Bildindize .ImageIndex, .SelectedIndex, .StateIndex, .ExpandedImageIndex und .OverlayIndex, außerdem .Enabled und die Zustände .Selected, .Focused und .Expanded, für jeden einzelnen Node. Ein TVirtualStringTree wird auch bald folgen, dort wird .Data dann ebenso über einen Callback gespeichert und geladen.
Delphi-Quellcode:
benutzen
Type TSTVProc = Procedure(Node: TXMLNode; TVNode: TTreeNode);
TSTVSavedData = Set of (ssImageIndex, ssSelectedIndex, ssStateIndex, ssExpandedIndex, ssOverlayIndex, ssEnabled, ssSelected, ssFocused, ssExpanded, ssData); Const ssDefault = [ssImageIndex..ssSelected, ssExpanded]; Procedure SerializeTreeView(Node: TXMLNode; TreeView: TTreeView; Save: TSTVSavedData = ssDefault; DataProc: TSTVProc = nil); Procedure DeserializeTreeView(Node: TXMLNode; TreeView: TTreeView; Load: TSTVSavedData = ssDefault; DataProc: TSTVProc = nil);
Delphi-Quellcode:
Dieser und ähnliche Codes werden allerdings wohl nie direkt im Projekt enthalten sein, da sie einfach zu speziell sind,
Var XML: TXMLFile;
Node: TXMLNode; // speichern XML := TXMLFile.Create; Node := XML.AddNode('MyTreeView'); SerializeTreeView(Node, TreeView1); XML.SaveToFile('file.xml'); XML.Free; // laden XML := TXMLFile.Create; XML.LoadFromFile('file.xml'); Node := XML.Node['MyTreeView']; DeserializeTreeView(Node, TreeView1); XML.Free; aber es ist eine kleine Abteilung auf der zukünftigen Webseite vorgesehn. [edit] der ganze Code kommt gleich wieder ... dann als Anhang in 'ner eigenen Unit so, da isser wieder :) [add] nun auch getestet, etwas geändert und mit Beispiel, siehe Bild |
Re: himXML (gesprochen himix ML)
Bis auf ein paar interne Sachen wurden vorallem ein paar neue Property eingefügt.
FindNode, FindNodes, FindNodeNF und FindNodesNF sind nun in den NodeListen zu finden, sowie als Weiterleitung im RootDokument und den Nodes. Diese sind fast das Selbe wie die Property Node und NodeList, nur daß sie die gewünscheten Nodes nicht NUR direkt im gewählten Node/Dokument suchen, sondern auch in allen SubNodes. Als NodeName/Pfad kann hier die selbe Syntax verwendet werden, wie bei den normalen Nodes, wodurch man z.B. auch ganze Pfade suchen kann. XML.FindNode['MeinNode'] würde also den ersten Node mit dem Namen "MeinNode" zurückliefern, welcher irgendwo innerhalb des RootNode oder seinen SubNodes rumliegt. Für Einzelnodes (ohne Pfadangabe) wird dieses Verhalten demnächst auch in den "normalen" Node und Node-Listen verfügbar sein ... ich glaub ich werde dieses über das Präfix @ dort integrieren. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:43 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz