/vqdr/trunk

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/vqdr/trunk

« back to all changes in this revision

Viewing changes to src/utils/utils.vala

  • Committer: Gustav Hartvigsson
  • Date: 2021-11-16 12:44:52 UTC
  • Revision ID: gustav.hartvigsson@gmail.com-20211116124452-g9245bvzwcyy9wk9
Added licencing information.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
namespace VQDR.Common.Utils {
 
1
/*
 
2
 * The contects of this file is in the Public Domain.
 
3
 *
 
4
 * Created by Gustav Hartivgsson.
 
5
 */
 
6
 
 
7
namespace Utils {
2
8
  public int str_cmp (string a, string b) {
3
9
    return a.collate (b);
4
10
  }
14
20
  }
15
21
  
16
22
  public string object_to_string (GLib.Object obj) {
17
 
    GLib.ObjectClass real_obj = (GLib.ObjectClass) obj.get_type ().class_ref ();
18
 
    
19
 
    var str_builder = new GLib.StringBuilder ();
20
 
    
21
 
    
22
 
    str_builder.append ("(")
 
23
     StringBuilder strbldr = new StringBuilder ();
 
24
     internal_object_to_string (obj, ref strbldr);
 
25
     return strbldr.str;
 
26
  }
 
27
 
 
28
  private unowned StringBuilder internal_object_to_string (GLib.Object obj,
 
29
                                                  ref StringBuilder str_builder,
 
30
                                                  int nesting = 0) {
 
31
    GLib.ObjectClass obj_class = (GLib.ObjectClass) obj.get_type ().class_ref ();
 
32
    
 
33
    for (var i = 0; i < nesting; i++) {
 
34
     str_builder.append ("\t");
 
35
    }
 
36
    
 
37
    str_builder.append ("((")
23
38
               .append (obj.get_type().name ())
24
 
               .append ("):\n");
 
39
               .append_printf (")->(%p):\n", obj);
25
40
    
26
 
    foreach (GLib.ParamSpec ps in real_obj.list_properties ()) {
 
41
    foreach (GLib.ParamSpec ps in obj_class.list_properties ()) {
27
42
      
28
43
      if (ps.value_type == 0 || ps.value_type == GLib.Type.INVALID) {
29
44
        continue;
36
51
      if (prop_val.type () == GLib.Type.INVALID || prop_val.type () == 0) {
37
52
        continue;
38
53
      }
39
 
      
 
54
 
40
55
      obj.get_property (prop_name, ref prop_val);
41
56
      
42
 
      
43
 
      str_builder.append ("\t (")
 
57
      for (var i = 0; i < nesting; i++) {
 
58
        str_builder.append ("\t");
 
59
      }
 
60
 
 
61
      str_builder.append ("\t(")
44
62
                 .append (prop_val.type_name ())
45
63
                 .append (") ")
46
64
                 .append (prop_name)
47
 
                 .append (": ");
 
65
                 .append (":");
 
66
 
 
67
 
48
68
      
49
69
      
50
70
      switch (prop_val.type ()) {
51
71
        case (GLib.Type.STRING):
52
 
          str_builder.append (prop_val.get_string ());
 
72
          if (prop_val.dup_string () == null) {
 
73
            str_builder.append ("(null)");
 
74
          } else {
 
75
            str_builder.append (prop_val.dup_string ());
 
76
          }
53
77
        break;
54
78
        case (GLib.Type.INT):
55
79
          str_builder.append (prop_val.get_int ().to_string ());
71
95
          str_builder.append (prop_val.get_enum ().to_string ());
72
96
        break;
73
97
        case (GLib.Type.FLAGS):
74
 
          // Probobly needs better handling, but this will do.
 
98
          // TODO: Probobly needs better handling, but this will do.
75
99
          str_builder.append (prop_val.get_flags ().to_string ());
76
100
        break;
77
101
        case (GLib.Type.FLOAT):
83
107
        case (GLib.Type.LONG):
84
108
          str_builder.append (prop_val.get_long ().to_string ());
85
109
        break;
86
 
        case (GLib.Type.OBJECT):
87
 
          str_builder.append_printf ("%llX", (((long)((pointer)prop_val.get_object ()))));
88
 
        break;
89
 
        case (GLib.Type.PARAM):
90
 
          var spsc = prop_val.get_param ();
91
 
          str_builder.append ("name: ")
92
 
                     .append (spsc.name)
93
 
                     .append (" type: ")
94
 
                     .append (spsc.value_type.name ());
95
 
        break;
96
110
        case (GLib.Type.POINTER):
97
 
          str_builder.append_printf ("%llX", (((long)prop_val.get_pointer ())));
 
111
          str_builder.append ("(")
 
112
                     .append_printf ("%p", prop_val.get_pointer ());
 
113
          str_builder.append (")");
 
114
        break;
 
115
        case (GLib.Type.BOXED):
 
116
          str_builder.append ("(")
 
117
                     .append_printf ("%p", prop_val.get_boxed ());
 
118
          str_builder.append (")");
98
119
        break;
99
120
        case (GLib.Type.UCHAR):
100
121
          var v = prop_val.get_uchar ();
113
134
          str_builder.append (prop_val.get_ulong ().to_string ());
114
135
        break;
115
136
        case (GLib.Type.VARIANT):
116
 
          GLib.Variant v = prop_val.get_variant ();
117
 
          str_builder.append ("(\n")
118
 
                     .append (v.print (true))
119
 
                     .append ("\n)");
 
137
          GLib.Variant v = prop_val.dup_variant ();
 
138
          GLib.Variant? tv = null;
 
139
          unowned string ts1 = v.get_type_string ();
 
140
          str_builder.append ("")
 
141
                     .append (ts1)
 
142
                     .append ("\n\t(\n");
 
143
          GLib.VariantIter iter = v.iterator ();
 
144
          tv = iter.next_value ();
 
145
          while (tv != null) {
 
146
            unowned string ts2 = tv.get_type_string ();
 
147
            string tp = tv.print (true);
 
148
            str_builder.append ("\t\t((")
 
149
                       .append (ts2)
 
150
                       .append ("): ")
 
151
                       .append (tp)
 
152
                       .append (")\n");
 
153
            tv = iter.next_value ();
 
154
          }
 
155
          
120
156
        break;
121
 
      }
 
157
 
 
158
      }
 
159
      if (prop_val.type ().is_a (typeof (GLib.Object))) {
 
160
        var new_nesting = nesting + 1;
 
161
        GLib.Object? dup_obj = prop_val.dup_object ();
 
162
        str_builder.append_printf ("->(%p):\n", dup_obj);
 
163
        internal_object_to_string (dup_obj, ref str_builder, new_nesting);
 
164
      }
 
165
 
122
166
      str_builder.append ("\n");
123
 
      
124
 
    }
125
 
    
126
 
    return str_builder.str;
 
167
    }
 
168
    for (var i = 0; i < nesting; i++) {
 
169
      str_builder.append ("\t");
 
170
    }
 
171
    str_builder.append (")\n");
 
172
    return str_builder;
127
173
  }
128
174
  
129
175
}