<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>http://groupkos.com/dev/index.php?action=history&amp;feed=atom&amp;title=VB6_clsJSONNode</id>
	<title>VB6 clsJSONNode - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://groupkos.com/dev/index.php?action=history&amp;feed=atom&amp;title=VB6_clsJSONNode"/>
	<link rel="alternate" type="text/html" href="http://groupkos.com/dev/index.php?title=VB6_clsJSONNode&amp;action=history"/>
	<updated>2026-04-17T15:23:17Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.39.3</generator>
	<entry>
		<id>http://groupkos.com/dev/index.php?title=VB6_clsJSONNode&amp;diff=5590&amp;oldid=prev</id>
		<title>XenoEngineer: /* Test Form */</title>
		<link rel="alternate" type="text/html" href="http://groupkos.com/dev/index.php?title=VB6_clsJSONNode&amp;diff=5590&amp;oldid=prev"/>
		<updated>2026-03-01T04:19:52Z</updated>

		<summary type="html">&lt;p&gt;&lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;Test Form&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 04:19, 1 March 2026&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l200&quot;&gt;Line 200:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 200:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;==Test Form==&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;==Test Form==&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;pre style=&amp;quot;margin-left:3em; font:normal 14px terminal;&amp;quot;&amp;gt;&amp;#039;&amp;#039;   &lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;pre style=&amp;quot;margin-left:3em; font:normal 14px terminal;&amp;quot;&amp;gt;&amp;#039;&amp;#039;   &lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#039;&amp;#039;  &lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;clsJSONNOde&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#039;&amp;#039;  &lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;frmJSONNOdeTest&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#039;&amp;#039;  Copyright 2026 Don &amp;#039;XenoEngineer&amp;#039; Mitchell&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#039;&amp;#039;  Copyright 2026 Don &amp;#039;XenoEngineer&amp;#039; Mitchell&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#039;&amp;#039;&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#039;&amp;#039;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>XenoEngineer</name></author>
	</entry>
	<entry>
		<id>http://groupkos.com/dev/index.php?title=VB6_clsJSONNode&amp;diff=5589&amp;oldid=prev</id>
		<title>XenoEngineer: Created page with &quot;Category:VB6   ==VB6 Class Code== &lt;pre style=&quot;margin-left:3em; font:normal 14px terminal;&quot;&gt; &#039;&#039;  Class clsJSONNode  Option Explicit  Public Enum enumNodeType     enuObjectType     enuArrayType     enuValueType End Enum   Private Type udtJSONNode     nodeType    As enumNodeType     Object      As Scripting.Dictionary     Array       As Collection     value       As Variant End Type  Private m As udtJSONNode   Private Sub Class_Initialize()     &#039;&#039;  Default to object typ...&quot;</title>
		<link rel="alternate" type="text/html" href="http://groupkos.com/dev/index.php?title=VB6_clsJSONNode&amp;diff=5589&amp;oldid=prev"/>
		<updated>2026-03-01T04:19:14Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;&lt;a href=&quot;/dev/index.php/Category:VB6&quot; title=&quot;Category:VB6&quot;&gt;Category:VB6&lt;/a&gt;   ==VB6 Class Code== &amp;lt;pre style=&amp;quot;margin-left:3em; font:normal 14px terminal;&amp;quot;&amp;gt; &amp;#039;&amp;#039;  Class clsJSONNode  Option Explicit  Public Enum enumNodeType     enuObjectType     enuArrayType     enuValueType End Enum   Private Type udtJSONNode     nodeType    As enumNodeType     Object      As Scripting.Dictionary     Array       As Collection     value       As Variant End Type  Private m As udtJSONNode   Private Sub Class_Initialize()     &amp;#039;&amp;#039;  Default to object typ...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;[[Category:VB6]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==VB6 Class Code==&lt;br /&gt;
&amp;lt;pre style=&amp;quot;margin-left:3em; font:normal 14px terminal;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;#039;&amp;#039;  Class clsJSONNode&lt;br /&gt;
&lt;br /&gt;
Option Explicit&lt;br /&gt;
&lt;br /&gt;
Public Enum enumNodeType&lt;br /&gt;
    enuObjectType&lt;br /&gt;
    enuArrayType&lt;br /&gt;
    enuValueType&lt;br /&gt;
End Enum&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Private Type udtJSONNode&lt;br /&gt;
    nodeType    As enumNodeType&lt;br /&gt;
    Object      As Scripting.Dictionary&lt;br /&gt;
    Array       As Collection&lt;br /&gt;
    value       As Variant&lt;br /&gt;
End Type&lt;br /&gt;
&lt;br /&gt;
Private m As udtJSONNode&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Private Sub Class_Initialize()&lt;br /&gt;
    &amp;#039;&amp;#039;  Default to object type as associative array (Dictionary).&lt;br /&gt;
    m.nodeType = enuObjectType&lt;br /&gt;
    &lt;br /&gt;
    Set m.Object = New Scripting.Dictionary&lt;br /&gt;
End Sub&lt;br /&gt;
&lt;br /&gt;
Private Sub Class_Terminate()&lt;br /&gt;
    Set m.Object = Nothing&lt;br /&gt;
End Sub&lt;br /&gt;
&lt;br /&gt;
Public Function AddObject(key As String) As clsJSONNode&lt;br /&gt;
    If m.nodeType &amp;lt;&amp;gt; enuObjectType Then Err.Raise 5, , &amp;quot;Not an object&amp;quot;&lt;br /&gt;
    Dim child As New clsJSONNode&lt;br /&gt;
    &lt;br /&gt;
    child.InitObject&lt;br /&gt;
    &lt;br /&gt;
    m.Object.Add key, child&lt;br /&gt;
    Set AddObject = child&lt;br /&gt;
End Function&lt;br /&gt;
&lt;br /&gt;
Public Function AddArray(key As String) As clsJSONNode&lt;br /&gt;
    If m.nodeType &amp;lt;&amp;gt; enuObjectType Then Err.Raise 5, , &amp;quot;Not an object&amp;quot;&lt;br /&gt;
    &lt;br /&gt;
    Dim child As New clsJSONNode&lt;br /&gt;
    &lt;br /&gt;
    child.InitArray&lt;br /&gt;
    &lt;br /&gt;
    m.Object.Add key, child&lt;br /&gt;
    Set AddArray = child&lt;br /&gt;
    &lt;br /&gt;
End Function&lt;br /&gt;
&lt;br /&gt;
Public Function AddObjectValue(key As String, v As Variant) As clsJSONNode&lt;br /&gt;
    If m.nodeType &amp;lt;&amp;gt; enuObjectType Then Err.Raise 5, , &amp;quot;Not an object&amp;quot;&lt;br /&gt;
    Dim child As New clsJSONNode&lt;br /&gt;
    child.SetValue v&lt;br /&gt;
    m.Object.Add key, child&lt;br /&gt;
    Set AddObjectValue = child&lt;br /&gt;
End Function&lt;br /&gt;
&lt;br /&gt;
Public Function AddArrayValue(v As Variant) As clsJSONNode&lt;br /&gt;
    Dim child As New clsJSONNode&lt;br /&gt;
    &lt;br /&gt;
    If m.nodeType &amp;lt;&amp;gt; enuArrayType Then Err.Raise 5, , &amp;quot;Not an array&amp;quot;&lt;br /&gt;
    &lt;br /&gt;
    child.SetValue v&lt;br /&gt;
    m.Array.Add child&lt;br /&gt;
    Set AddArrayValue = child&lt;br /&gt;
End Function&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Public Sub InitObject()&lt;br /&gt;
    m.nodeType = enuObjectType&lt;br /&gt;
    Set m.Object = New Scripting.Dictionary&lt;br /&gt;
    &lt;br /&gt;
    Set m.Array = Nothing&lt;br /&gt;
    m.value = Empty&lt;br /&gt;
End Sub&lt;br /&gt;
&lt;br /&gt;
Public Sub InitArray()&lt;br /&gt;
    m.nodeType = enuArrayType&lt;br /&gt;
    Set m.Array = New Collection&lt;br /&gt;
    Set m.Object = Nothing&lt;br /&gt;
    m.value = Empty&lt;br /&gt;
End Sub&lt;br /&gt;
&lt;br /&gt;
Public Sub SetValue(v As Variant)&lt;br /&gt;
    m.nodeType = enuValueType&lt;br /&gt;
    m.value = v&lt;br /&gt;
    Set m.Object = Nothing&lt;br /&gt;
    Set m.Array = Nothing&lt;br /&gt;
End Sub&lt;br /&gt;
&lt;br /&gt;
Public Property Let nodeType(value As enumNodeType)&lt;br /&gt;
    m.nodeType = value&lt;br /&gt;
End Property&lt;br /&gt;
&lt;br /&gt;
Public Property Get nodeType() As enumNodeType&lt;br /&gt;
    nodeType = m.nodeType&lt;br /&gt;
End Property&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Public Function ToJSON(Indent As Integer) As String&lt;br /&gt;
    Dim json As String&lt;br /&gt;
    Dim i As Integer&lt;br /&gt;
    Dim spacer As String&lt;br /&gt;
&lt;br /&gt;
    &amp;#039; Create an indentation string&lt;br /&gt;
    For i = 1 To Indent&lt;br /&gt;
        spacer = spacer &amp;amp; &amp;quot;  &amp;quot;&lt;br /&gt;
    Next i&lt;br /&gt;
&lt;br /&gt;
    Select Case m.nodeType&lt;br /&gt;
        Case enuValueType&lt;br /&gt;
            ToJSON = ValueToString(m.value, Indent)&lt;br /&gt;
        Case enuObjectType&lt;br /&gt;
            ToJSON = ObjectToString(spacer, Indent)&lt;br /&gt;
        Case enuArrayType&lt;br /&gt;
            ToJSON = ArrayToString(spacer, Indent)&lt;br /&gt;
        Case Else&lt;br /&gt;
            Err.Raise 5, , &amp;quot;Invalid node type&amp;quot;&lt;br /&gt;
    End Select&lt;br /&gt;
End Function&lt;br /&gt;
&lt;br /&gt;
Private Function ValueToString(v As Variant, Indent As Integer) As String&lt;br /&gt;
    If VarType(v) = vbString Then&lt;br /&gt;
        ValueToString = &amp;quot;&amp;quot;&amp;quot;&amp;quot; &amp;amp; Replace(v, &amp;quot;&amp;quot;&amp;quot;&amp;quot;, &amp;quot;\&amp;quot;&amp;quot;&amp;quot;) &amp;amp; &amp;quot;&amp;quot;&amp;quot;&amp;quot;&lt;br /&gt;
    ElseIf VarType(v) = vbBoolean Then&lt;br /&gt;
        ValueToString = IIf(v, &amp;quot;true&amp;quot;, &amp;quot;false&amp;quot;)&lt;br /&gt;
    ElseIf VarType(v) = vbInteger Or VarType(v) = vbLong Or VarType(v) = vbSingle Or VarType(v) = vbDouble Then&lt;br /&gt;
        ValueToString = CStr(v)&lt;br /&gt;
    ElseIf IsNull(v) Then&lt;br /&gt;
        ValueToString = &amp;quot;null&amp;quot;&lt;br /&gt;
    Else&lt;br /&gt;
        Err.Raise 5, , &amp;quot;Unsupported value type&amp;quot;&lt;br /&gt;
    End If&lt;br /&gt;
End Function&lt;br /&gt;
&lt;br /&gt;
Private Function ObjectToString(spacer As String, Indent As Integer) As String&lt;br /&gt;
    Dim json As String&lt;br /&gt;
    Dim key As Variant&lt;br /&gt;
&lt;br /&gt;
    json = &amp;quot;{&amp;quot;&lt;br /&gt;
&lt;br /&gt;
    &amp;#039; Check if the object is not empty&lt;br /&gt;
    If m.Object.Count &amp;gt; 0 Then&lt;br /&gt;
        json = json &amp;amp; vbCrLf &amp;amp; spacer &amp;amp; &amp;quot;  &amp;quot;&lt;br /&gt;
        Dim first As Boolean&lt;br /&gt;
        first = True&lt;br /&gt;
        For Each key In m.Object.Keys&lt;br /&gt;
            If first = False Then&lt;br /&gt;
                json = json &amp;amp; &amp;quot;,&amp;quot; &amp;amp; vbCrLf &amp;amp; spacer &amp;amp; &amp;quot;  &amp;quot;&lt;br /&gt;
            Else&lt;br /&gt;
                first = False&lt;br /&gt;
            End If&lt;br /&gt;
            json = json &amp;amp; &amp;quot;&amp;quot;&amp;quot;&amp;quot; &amp;amp; key &amp;amp; &amp;quot;&amp;quot;&amp;quot;&amp;quot; &amp;amp; &amp;quot;: &amp;quot; &amp;amp; m.Object(key).ToJSON(Indent + 1)&lt;br /&gt;
        Next key&lt;br /&gt;
        json = json &amp;amp; vbCrLf &amp;amp; spacer &amp;amp; &amp;quot;}&amp;quot;&lt;br /&gt;
    Else&lt;br /&gt;
        json = json &amp;amp; &amp;quot;}&amp;quot;&lt;br /&gt;
    End If&lt;br /&gt;
&lt;br /&gt;
    ObjectToString = json&lt;br /&gt;
End Function&lt;br /&gt;
&lt;br /&gt;
Private Function ArrayToString(spacer As String, Indent As Integer) As String&lt;br /&gt;
    Dim json As String&lt;br /&gt;
    Dim i As Long&lt;br /&gt;
&lt;br /&gt;
    json = &amp;quot;[&amp;quot;&lt;br /&gt;
&lt;br /&gt;
    &amp;#039; Check if the array is not empty&lt;br /&gt;
    If m.Array.Count &amp;gt; 0 Then&lt;br /&gt;
        json = json &amp;amp; vbCrLf &amp;amp; spacer &amp;amp; &amp;quot;  &amp;quot;&lt;br /&gt;
        For i = 1 To m.Array.Count&lt;br /&gt;
            If i &amp;gt; 1 Then json = json &amp;amp; &amp;quot;,&amp;quot; &amp;amp; vbCrLf &amp;amp; spacer &amp;amp; &amp;quot;  &amp;quot;&lt;br /&gt;
            json = json &amp;amp; m.Array(i).ToJSON(Indent + 1)&lt;br /&gt;
        Next i&lt;br /&gt;
        json = json &amp;amp; vbCrLf &amp;amp; spacer &amp;amp; &amp;quot;]&amp;quot;&lt;br /&gt;
    Else&lt;br /&gt;
        json = json &amp;amp; &amp;quot;]&amp;quot;&lt;br /&gt;
    End If&lt;br /&gt;
&lt;br /&gt;
    ArrayToString = json&lt;br /&gt;
End Function&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Test Form==&lt;br /&gt;
&amp;lt;pre style=&amp;quot;margin-left:3em; font:normal 14px terminal;&amp;quot;&amp;gt;&amp;#039;&amp;#039;  &lt;br /&gt;
&amp;#039;&amp;#039;  clsJSONNOde&lt;br /&gt;
&amp;#039;&amp;#039;  Copyright 2026 Don &amp;#039;XenoEngineer&amp;#039; Mitchell&lt;br /&gt;
&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Option Explicit&lt;br /&gt;
&lt;br /&gt;
Private Type udtForm&lt;br /&gt;
    root        As clsJSONNode&lt;br /&gt;
    objectFile  As String&lt;br /&gt;
End Type&lt;br /&gt;
&lt;br /&gt;
Private m As udtForm&lt;br /&gt;
&lt;br /&gt;
                    &lt;br /&gt;
Private Sub cmdAddRoot_Click()&lt;br /&gt;
    Set m.root = New clsJSONNode&lt;br /&gt;
    &lt;br /&gt;
    m.root.InitObject&lt;br /&gt;
    &lt;br /&gt;
    With m.root.AddObject(&amp;quot;user&amp;quot;)&lt;br /&gt;
        .AddObjectValue &amp;quot;name&amp;quot;, txtName.Text&lt;br /&gt;
        .AddObjectValue &amp;quot;age&amp;quot;, txtAge.Text&lt;br /&gt;
        With .AddArray(&amp;quot;roles&amp;quot;)&lt;br /&gt;
            .AddArrayValue txtRole1.Text&lt;br /&gt;
            .AddArrayValue txtRole2.Text&lt;br /&gt;
        End With&lt;br /&gt;
    End With&lt;br /&gt;
    &lt;br /&gt;
    txtJSON.Text = m.root.ToJSON(1)&lt;br /&gt;
    Debug.Print m.root.ToJSON(Indent:=2)&lt;br /&gt;
End Sub&lt;br /&gt;
&lt;br /&gt;
Private Sub Form_KeyPress(KeyAscii As Integer)&lt;br /&gt;
    Select Case KeyAscii&lt;br /&gt;
        Case vbKeyEscape&lt;br /&gt;
            Unload Me&lt;br /&gt;
        Case Else&lt;br /&gt;
    End Select&lt;br /&gt;
End Sub&lt;br /&gt;
&lt;br /&gt;
Private Sub Form_Load()&lt;br /&gt;
    Me.KeyPreview = True&lt;br /&gt;
End Sub&lt;br /&gt;
&lt;br /&gt;
Private Sub Form_Terminate()&lt;br /&gt;
    Set m.root = Nothing&lt;br /&gt;
End Sub&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>XenoEngineer</name></author>
	</entry>
</feed>