src/js/libs/tracemanager.js
author veltr
Tue, 03 Apr 2012 20:30:12 +0200
branchpopcorn-port
changeset 841 8da49ff273e0
parent 835 a8af9da7c622
child 882 61c384dda19e
child 899 445631dffdf8
permissions -rw-r--r--
Modifs cinecast
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
     1
/*
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
     2
 * Modelled Trace API
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
     3
 */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
     4
IriSP.TraceManager = function($) {
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
     5
     // If there are more than MAX_FAILURE_COUNT synchronisation
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
     6
     // failures, then disable synchronisation
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
     7
     MAX_FAILURE_COUNT = 20;
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
     8
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
     9
     // If there are more than MAX_BUFFER_SIZE obsels in the buffer,
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    10
     // then "compress" them as a single "ktbsFullBuffer"
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    11
     MAX_BUFFER_SIZE = 500;
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    12
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    13
     var BufferedService_prototype = {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    14
         /*
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    15
          *  Buffered service for traces
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    16
          */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    17
         // url: "",
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    18
         // buffer: [],
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    19
         // isReady: false,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    20
         // timer: null,
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    21
         // failureCount: 0,
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    22
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    23
         /* Flush buffer */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    24
         flush: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    25
             // FIXME: add mutex on this.buffer
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    26
             if (! this.isReady)
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    27
             {
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    28
                 if (window.console) window.console.log("Sync service not ready");
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    29
             } else if (this.failureCount > MAX_FAILURE_COUNT)
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    30
             {
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    31
                 // Disable synchronisation
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    32
                 this.set_sync_mode('none');
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    33
             } else if (this.buffer.length) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    34
                 var temp = this.buffer;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    35
                 this.buffer = [];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    36
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    37
                 if (this.mode == 'GET')
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    38
                 {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    39
                     // GET mode: do some data mangline. We mark the
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    40
                     // "compressed" nature of the generated JSON by
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    41
                     // prefixing it with c
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    42
                     var data = 'c' + JSON.stringify(temp.map(function (o) { return o.toCompactJSON(); }));
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    43
                     // Swap " (very frequent, which will be
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    44
                     // serialized into %22) and ; (rather rare), this
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    45
                     // saves some bytes
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    46
                     data = data.replace(/[;"]/g, function(s){ return s == ';' ? '"' : ';'; }).replace(/#/g, '%23');
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    47
                     // FIXME: check data length (< 2K is safe)
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    48
                     var request=$('<img />').error( function() { this.failureCount += 1; })
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    49
                         .load( function() { this.failureCount = 0; })
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    50
                         .attr('src', this.url + 'trace/?data=' + data);
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    51
                 }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    52
                 else
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    53
                 {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    54
                     $.ajax({ url: this.url + 'trace/',
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    55
                              type: 'POST',
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    56
                              contentType: 'application/json',
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    57
                              data: JSON.stringify(temp.map(function (o) { return o.toJSON(); })),
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    58
                              processData: false,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    59
                              // Type of the returned data.
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    60
                              dataType: "html",
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    61
                              error: function(jqXHR, textStatus, errorThrown) {
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    62
                                  if (window.console) window.console.log("Error when sending buffer:", textStatus);
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    63
                                  this.failureCount += 1;
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    64
                              },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    65
                              success: function(data, textStatus, jqXHR) {
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    66
                                  // Reset failureCount to 0 as soon as there is 1 valid answer
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    67
                                  this.failureCount = 0;
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    68
                              }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    69
                            });
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    70
                 }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    71
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    72
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    73
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    74
         /* Sync mode: delayed, sync (immediate sync), none (no
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    75
          * synchronisation with server, the trace has to be explicitly saved
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    76
          * if needed */
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    77
         set_sync_mode: function(mode) {
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    78
             this.sync_mode = mode;
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    79
             if (! this.isReady && mode !== "none")
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    80
                 this.init();
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    81
             if (mode == 'delayed') {
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    82
                 this.start_timer();
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    83
             } else {
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    84
                 this.stop_timer();
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    85
             }
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    86
         },
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    87
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    88
         /* Enqueue an obsel */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    89
         enqueue: function(obsel) {
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    90
             if (this.buffer.length > MAX_BUFFER_SIZE)
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    91
             {
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    92
                 obsel = new Obsel('ktbsFullBuffer', this.buffer[0].begin,
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    93
                                   this.buffer[this.buffer.length - 1].end, this.buffer[0].subject);
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    94
                 obsel.trace = this.buffer[0].trace;
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    95
                 this.buffer = [];
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    96
             }
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
    97
             this.buffer.push(obsel);
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    98
             if (this.sync_mode === 'sync') {
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
    99
                 // Immediate sync of the obsel.
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   100
                 this.flush();
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   101
             }
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   102
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   103
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   104
         start_timer: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   105
             var self = this;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   106
             if (this.timer === null) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   107
                 this.timer = window.setInterval(function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   108
                                                     self.flush();
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   109
                                                 }, this.timeOut);
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   110
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   111
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   112
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   113
         stop_timer: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   114
             if (this.timer !== null) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   115
                 window.clearInterval(this.timer);
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   116
                 this.timer = null;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   117
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   118
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   119
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   120
         /*
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   121
          * Initialize the sync service
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   122
          */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   123
         init: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   124
             var self = this;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   125
             if (this.isReady)
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   126
                 /* Already initialized */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   127
                 return;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   128
             if (this.mode == 'GET')
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   129
             {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   130
                 var request=$('<img/>').attr('src', this.url + 'login?userinfo={"name":"ktbs4js"}');
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   131
                 // Do not wait for the return, assume it is
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   132
                 // initialized. This assumption will not work anymore
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   133
                 // if login returns some necessary information
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   134
                 this.isReady = true;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   135
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   136
             else
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   137
             {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   138
                 $.ajax({ url: this.url + 'login',
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   139
                          type: 'POST',
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   140
                          data: 'userinfo={"name":"ktbs4js"}',
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   141
                          success: function(data, textStatus, jqXHR) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   142
                              self.isReady = true;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   143
                              if (self.buffer.length) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   144
                                  self.flush();
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   145
                              }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   146
                          }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   147
                        });
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   148
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   149
         }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   150
     };
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   151
     var BufferedService = function(url, mode) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   152
         this.url = url;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   153
         this.buffer = [];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   154
         this.isReady = false;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   155
         this.timer = null;
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   156
         this.failureCount = 0;
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   157
         // sync_mode is either "none", "sync" or "buffered"
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   158
         this.sync_mode = "none";
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   159
         /* mode can be either POST or GET */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   160
         if (mode == 'POST' || mode == 'GET')
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   161
             this.mode = mode;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   162
         else
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   163
             this.mode = 'POST';
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   164
         /* Flush buffer every timeOut ms if the sync_mode is delayed */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   165
         this.timeOut = 2000;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   166
     };
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   167
     BufferedService.prototype = BufferedService_prototype;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   168
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   169
     var Trace_prototype = {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   170
         /* FIXME: We could/should use a sorted list such as
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   171
          http://closure-library.googlecode.com/svn/docs/class_goog_structs_AvlTree.html
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   172
          to speed up queries based on time */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   173
         obsels: [],
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   174
         /* Trace URI */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   175
         uri: "",
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   176
         default_subject: "",
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   177
         /* baseuri is used as the base URI to resolve relative
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   178
          * attribute-type names in obsels. Strictly speaking, this
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   179
          * should rather be expressed as a reference to model, or
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   180
          * more generically, as a qname/URI dict */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   181
         baseuri: "",
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   182
         /* Mapping of obsel type or property name to a compact
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   183
          * representation (shorthands).
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   184
          */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   185
         shorthands: null,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   186
         syncservice: null,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   187
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   188
         /* Define the trace URI */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   189
         set_uri: function(uri) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   190
             this.uri = uri;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   191
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   192
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   193
         /* Sync mode: delayed, sync (immediate sync), none (no
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   194
          * synchronisation with server, the trace has to be explicitly saved
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   195
          * if needed */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   196
         set_sync_mode: function(mode) {
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   197
             if (this.syncservice !== null) {
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   198
                 this.syncservice.set_sync_mode(mode);
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   199
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   200
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   201
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   202
         /*
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   203
          * Return a list of the obsels of this trace matching the parameters
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   204
          */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   205
         list_obsels: function(_begin, _end, _reverse) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   206
             var res;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   207
             if (typeof _begin !== 'undefined' || typeof _end !== 'undefined') {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   208
                 /*
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   209
                  * Not optimized yet.
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   210
                  */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   211
                 res = [];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   212
                 var l = this.obsels.length;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   213
                 for (var i = 0; i < l; i++) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   214
                     var o = this.obsels[i];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   215
                     if ((typeof _begin !== 'undefined' && o.begin > _begin) && (typeof _end !== 'undefined' && o.end < _end)) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   216
                         res.push(o);
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   217
                     }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   218
                 }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   219
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   220
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   221
             if (typeof _reverse !== 'undefined') {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   222
                 if (res !== undefined) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   223
                     /* Should reverse the whole list. Make a copy. */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   224
                     res = this.obsels.slice(0);
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   225
                 }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   226
                 res.sort(function(a, b) { return b.begin - a.begin; });
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   227
                 return res;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   228
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   229
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   230
             if (res === undefined) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   231
                 res = this.obsels;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   232
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   233
             return res;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   234
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   235
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   236
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   237
         /*
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   238
          * Return the obsel of this trace identified by the URI, or undefined
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   239
          */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   240
         get_obsel: function(id) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   241
             for (var i = 0; i < this.obsels.length; i++) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   242
                 /* FIXME: should check against variations of id/uri, take this.baseuri into account */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   243
                 if (this.obsels[i].uri === id) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   244
                     return this.obsels[i];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   245
                 }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   246
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   247
             return undefined;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   248
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   249
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   250
         set_default_subject: function(subject) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   251
             this.default_subject = subject;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   252
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   253
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   254
         get_default_subject: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   255
             return this.default_subject;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   256
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   257
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   258
         /* (type:ObselType, begin:int, end:int?, subject:str?, attributes:[AttributeType=>any]?) */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   259
         /* Create a new obsel and add it to the trace */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   260
         create_obsel: function(type, begin, end, subject, _attributes) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   261
             var o = new Obsel(type, begin, end, subject);
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   262
             if (typeof _attributes !== 'undefined') {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   263
                 o.attributes = _attributes;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   264
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   265
             o.trace = this;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   266
             this.obsels.push(o);
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   267
             if (this.syncservice !== null)
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   268
                 this.syncservice.enqueue(o);
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   269
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   270
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   271
         /* Helper methods */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   272
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   273
         /* Create a new obsel with the given attributes */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   274
         trace: function(type, _attributes, _begin, _end, _subject) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   275
             var t = (new Date()).getTime();
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   276
             if (typeof begin === 'undefined') {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   277
                 _begin = t;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   278
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   279
             if (typeof end === 'undefined') {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   280
                 _end = _begin;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   281
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   282
             if (typeof subject === 'undefined') {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   283
                 _subject = this.default_subject;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   284
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   285
             if (typeof _attributes === 'undefined') {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   286
                 _attributes = {};
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   287
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   288
             return this.create_obsel(type, _begin, _end, _subject, _attributes);
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   289
         }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   290
     };
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   291
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   292
     var Trace = function(uri, requestmode) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   293
         /* FIXME: We could/should use a sorted list such as
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   294
          http://closure-library.googlecode.com/svn/docs/class_goog_structs_AvlTree.html
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   295
          to speed up queries based on time */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   296
         this.obsels = [];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   297
         /* Trace URI */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   298
         if (uri === undefined)
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   299
             uri = "";
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   300
         this.uri = uri;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   301
         this.sync_mode = "none";
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   302
         this.default_subject = "";
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   303
         this.shorthands = {};
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   304
         /* baseuri is used a the base URI to resolve relative attribute names in obsels */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   305
         this.baseuri = "";
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   306
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   307
         this.syncservice = new BufferedService(uri, requestmode);
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   308
         $(window).unload( function () {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   309
                               if (this.syncservice && this.sync_mode !== 'none') {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   310
                                   this.syncservice.flush();
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   311
                                   this.syncservice.stop_timer();
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   312
                               }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   313
                           });
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   314
     };
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   315
     Trace.prototype = Trace_prototype;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   316
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   317
     var Obsel_prototype = {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   318
         /* The following attributes are here for documentation
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   319
          * purposes. They MUST be defined in the constructor
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   320
          * function. */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   321
         trace: undefined,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   322
         type: undefined,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   323
         begin: undefined,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   324
         end: undefined,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   325
         subject: undefined,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   326
         /* Dictionary indexed by ObselType URIs */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   327
         attributes: {},
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   328
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   329
         /* Method definitions */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   330
         get_trace: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   331
             return this.trace;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   332
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   333
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   334
         get_obsel_type: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   335
             return this.type;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   336
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   337
         get_begin: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   338
             return this.begin;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   339
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   340
         get_end: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   341
             return this.end;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   342
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   343
         get_subject: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   344
             return this.subject;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   345
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   346
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   347
         list_attribute_types: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   348
             var result = [];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   349
             for (var prop in this.attributes) {
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   350
                 if (this.hasOwnProperty(prop))
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   351
                     result.push(prop);
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   352
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   353
             /* FIXME: we return URIs here instead of AttributeType elements */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   354
             return result;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   355
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   356
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   357
         list_relation_types: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   358
             /* FIXME: not implemented yet */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   359
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   360
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   361
         list_related_obsels: function (rt) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   362
             /* FIXME: not implemented yet */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   363
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   364
         list_inverse_relation_types: function () {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   365
             /* FIXME: not implemented yet */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   366
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   367
         list_relating_obsels: function (rt) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   368
             /* FIXME: not implemented yet */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   369
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   370
         /*
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   371
          * Return the value of the given attribute type for this obsel
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   372
          */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   373
         get_attribute_value: function(at) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   374
             if (typeof at === "string")
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   375
                 /* It is a URI */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   376
                 return this.attributes[at];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   377
             else
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   378
                 /* FIXME: check that at is instance of AttributeType */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   379
                 return this.attributes[at.uri];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   380
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   381
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   382
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   383
         /* obsel modification (trace amendment) */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   384
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   385
         set_attribute_value: function(at, value) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   386
             if (typeof at === "string")
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   387
                 /* It is a URI */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   388
                 this.attributes[at] = value;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   389
             /* FIXME: check that at is instance of AttributeType */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   390
             else
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   391
                 this.attributes[at.uri] = value;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   392
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   393
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   394
         del_attribute_value: function(at) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   395
             if (typeof at === "string")
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   396
                 /* It is a URI */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   397
                 delete this.attributes[at];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   398
             /* FIXME: check that at is instance of AttributeType */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   399
             else
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   400
                 delete this.attributes[at.uri];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   401
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   402
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   403
         add_related_obsel: function(rt, value) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   404
             /* FIXME: not implemented yet */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   405
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   406
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   407
         del_related_obsel: function(rt, value) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   408
             /* FIXME: not implemented yet */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   409
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   410
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   411
         /*
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   412
          * Return a JSON representation of the obsel
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   413
          */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   414
         toJSON: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   415
             var r = {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   416
                 "@id": this.id,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   417
                 "@type": this.type,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   418
                 "begin": this.begin,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   419
                 "end": this.end,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   420
                 "subject": this.subject
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   421
             };
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   422
             for (var prop in this.attributes) {
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   423
                 if (this.hasOwnProperty(prop))
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   424
                     r[prop] = this.attributes[prop];
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   425
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   426
             return r;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   427
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   428
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   429
         /*
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   430
          * Return a compact JSON representation of the obsel.
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   431
          * Use predefined + custom shorthands for types/properties
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   432
          */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   433
         toCompactJSON: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   434
             var r = {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   435
                 "@i": this.id,
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   436
                 "@t": (this.trace.shorthands.hasOwnProperty(this.type) ? this.trace.shorthands[this.type] : this.type),
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   437
                 "@b": this.begin,
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   438
                 "@s": this.subject
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   439
             };
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   440
             // Store duration (to save some bytes) and only if it is non-null
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   441
             if (this.begin !== this.end)
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   442
                 r["@d"] = this.end - this.begin;
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   443
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   444
             for (var prop in this.attributes) {
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   445
                 if (this.hasOwnProperty(prop))
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   446
                 {
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   447
                     var v = this.attributes[prop];
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   448
                     r[prop] = this.trace.shorthands.hasOwnProperty(v) ? this.trace.shorthands[v] : v;
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   449
                 }
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   450
             }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   451
             return r;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   452
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   453
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   454
         toJSONstring: function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   455
             return JSON.stringify(this.toJSON());
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   456
         }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   457
     };
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   458
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   459
     var Obsel = function(type, begin, end, subject, attributes) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   460
         this.trace = undefined;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   461
         this.uri = "";
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   462
         this.id = "";
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   463
         this.type = type;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   464
         this.begin = begin;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   465
         this.end = end;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   466
         this.subject = subject;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   467
         /* Is the obsel synched with the server ? */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   468
         this.sync_status = false;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   469
         /* Dictionary indexed by ObselType URIs */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   470
         this.attributes = {};
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   471
     };
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   472
     Obsel.prototype = Obsel_prototype;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   473
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   474
     var TraceManager_prototype = {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   475
         traces: [],
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   476
         /*
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   477
          * Return the trace with id name
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   478
          * If it was not registered, return undefined.
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   479
          */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   480
         get_trace: function(name) {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   481
             return this.traces[name];
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   482
         },
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   483
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   484
         /*
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   485
          * Explicitly create and initialize a new trace with the given name.
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   486
          * The optional uri parameter allows to initialize the trace URI.
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   487
          *
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   488
          * If another existed with the same name before, then it is replaced by a new one.
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   489
          */
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   490
         init_trace: function(name, params)
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   491
         {
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   492
             if (window.console) window.console.log("init_trace", params);
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   493
             url = params.url ? params.url : "";
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   494
             requestmode = params.requestmode ? params.requestmode : "POST";
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   495
             syncmode = params.syncmode ? params.syncmode : "none";
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   496
             default_subject = params.default_subject ? params.default_subject : "default";
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   497
             var t = new Trace(url, requestmode);
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   498
             t.set_sync_mode(syncmode);
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   499
             t.set_default_subject(default_subject);
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   500
             this.traces[name] = t;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   501
             return t;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   502
         }
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   503
     };
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   504
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   505
     var TraceManager = function() {
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   506
         this.traces = {};
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   507
     };
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   508
     TraceManager.prototype = TraceManager_prototype;
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   509
841
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   510
     var tracemanager  = new TraceManager();
8da49ff273e0 Modifs cinecast
veltr
parents: 835
diff changeset
   511
     return tracemanager;
835
a8af9da7c622 Integrated trace manager
veltr
parents:
diff changeset
   512
 };