(Declarations) Dim session As NotesSession Dim inputStream As NotesStream, outputStream As NotesStream Dim domParser As NotesDOMParser Dim docNode As NotesDOMDocumentNode Dim NL As String 'carriage return + line feed Dim nodeCount(12) As Long
Sub Initialize Dim i As Integer Dim j As Long Dim origXML As String, outputFile As String origXML = "c:\dxl\NAB.xml" outputFile = "c:\dxl\DOMnodes.doc" REM your message here! Dim message As String message = "DOM Parser Report - Node Relationships" On Error Goto errh 'open the XML input file and create the report file If Not xmlCreate(origXML,outputFile,message) Then Goto results End If 'create DOM parser and process Set domParser=session.CreateDOMParser(inputStream, outputStream) domParser.Process 'get the document node Set docNode = domParser.Document REM report on parent/child/sibling nodes For i = 0 To 12 nodeCount(i) = 0 Next Call walktree (docNode) outputStream.WriteText (NL+NL+"Report status ---"+NL) For j = 0 To 12 outputStream.WriteText (Cstr(nodeCount(j))+" "+CstrNodeType(j)+"s"+ NL) Next message = NL+"end of file: "+origXML results: outputStream.WriteText (message) Call outputStream.Close Messagebox "Report written to "+outputFile Exit Sub errh: message = Cstr(Err)+": "+Error+Chr(13) Resume results End Sub
Sub walkTree ( node As NotesDOMNode) Dim child As NotesDOMNode Dim numChildNodes As Integer Dim nName As String NL = Chr(13)+Chr(10) If Not node.IsNull Then nName = CstrNodeType(node.NodeType) domParser.Output( nName+" " ) Select Case node.NodeType Case DOMNODETYPE_DOCUMENT_NODE: ' The Document node domParser.Output("Name: "+node.Nodename+NL) If node.ParentNode.IsNull Then domParser.Output(nName+"s have no parent") Else Messagebox "Node cannot have a parent!!", ,nName+" error" Exit Sub End If If node.NextSibling.IsNull And node.PreviousSibling.IsNull Then domParser.Output(" and no siblings"+NL ) Else Messagebox "Node cannot have a sibling!!", ,nName+" error" Exit Sub End If Case Else: domParser.Output("Name: "+node.Nodename+NL) If node.ParentNode.Isnull Then Messagebox "Node must have a parent!!", ,nName+" error" Exit Sub End If If node.NextSibling.IsNull And node.PreviousSibling.IsNull Then domParser.Output(" has no siblings" ) Else domParser.Output(" has a sibling") End If End Select 'node.NodeType If node.HasChildNodes Then Set child = node.FirstChild numChildNodes = node.NumberOfChildNodes If node.NodeType = DOMNODETYPE_DOCUMENT_NODE Then domParser.Output(" has "+Cstr(numChildNodes) ) Else domParser.Output(" and "+Cstr(numChildNodes) ) End If If numChildNodes = 1 Then domParser.Output( " child"+NL) Else domParser.Output( " children"+NL) End If While numChildNodes > 0 Call walkTree(child) Set child = child.NextSibling numChildNodes = numChildNodes - 1 Wend Else domParser.Output(" and no children"+NL) End If 'node.HasChildNodes End If 'Not node.IsNull End Sub
Function xmlCreate (inFile As String, outFile As String, info As String) ' Open the XML file and create the report file Dim db As NotesDatabase Set session = New NotesSession Set db = session.CurrentDatabase 'create the output file Set outputStream =session.CreateStream outputStream.Open (outFile) outputStream.Truncate 'write report title outputStream.WriteText (info+Chr(13)+Chr(10)) 'open the XML file Set inputStream = session.CreateStream inputStream.Open (inFile) If inputStream.Bytes = 0 Then info = "XML file "+ inFile+" is empty" xmlCreate = False Else xmlCreate = True End If End Function
Function CstrNodeType (currentNode As Long) As String 'Given a node type, convert it to a descriptive string. nodeCount(currentNode) = nodeCount(currentNode)+1 Select Case currentNode Case DOMNODETYPE_ELEMENT_NODE: '1 CstrNodeType = "ELEMENT_NODE" Case DOMNODETYPE_ATTRIBUTE_NODE: '2 CstrNodeType = "ATTRIBUTE_NODE" Case DOMNODETYPE_TEXT_NODE: '3 CstrNodeType = "TEXT_NODE" Case DOMNODETYPE_CDATASECTION_NODE: '4 CstrNodeType = "CDATASECTION_NODE" Case DOMNODETYPE_ENTITYREFERENCE_NODE: '5 CstrNodeType = "ENTITYREFERENCE_NODE" Case DOMNODETYPE_ENTITY_NODE: '6 CstrNodeType = "ENTITY_NODE" Case DOMNODETYPE_PROCESSINGINSTRUCTION_NODE: '7 CstrNodeType = "PROCESSINGINSTRUCTION_NODE" Case DOMNODETYPE_COMMENT_NODE: '8 CstrNodeType = "COMMENT_NODE" Case DOMNODETYPE_DOCUMENT_NODE: '9 CstrNodeType = "DOCUMENT_NODE" Case DOMNODETYPE_DOCUMENTTYPE_NODE: '10 CstrNodeType = "DOCUMENTTYPE_NODE" Case DOMNODETYPE_DOCUMENTFRAGMENT_NODE: '11 CstrNodeType = "DOCUMENTFRAGMENT_NODE" Case DOMNODETYPE_NOTATION_NODE: '12 CstrNodeType = "NOTATION_NODE" Case DOMNODETYPE_XMLDECL_NODE: '13 CstrNodeType = "XMLDECL_NODE" End Select End Function
See Also