Stack sampling profiler: add fire-and-forget interface
[chromium-blink-merge.git] / components / metrics / serialization / serialization_utils.h
blob17e5e4cebc550d654296413448af4d6e00ec6b67
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef COMPONENTS_METRICS_SERIALIZATION_SERIALIZATION_UTILS_H_
6 #define COMPONENTS_METRICS_SERIALIZATION_SERIALIZATION_UTILS_H_
8 #include <string>
10 #include "base/memory/scoped_ptr.h"
11 #include "base/memory/scoped_vector.h"
13 namespace metrics {
15 class MetricSample;
17 // Metrics helpers to serialize and deserialize metrics collected by
18 // ChromeOS.
19 namespace SerializationUtils {
21 // Deserializes a sample passed as a string and return a sample.
22 // The return value will either be a scoped_ptr to a Metric sample (if the
23 // deserialization was successful) or a NULL scoped_ptr.
24 scoped_ptr<MetricSample> ParseSample(const std::string& sample);
26 // Reads all samples from a file and truncate the file when done.
27 void ReadAndTruncateMetricsFromFile(const std::string& filename,
28 ScopedVector<MetricSample>* metrics);
30 // Serializes a sample and write it to filename.
31 // The format for the message is:
32 // message_size, serialized_message
33 // where
34 // * message_size is the total length of the message (message_size +
35 // serialized_message) on 4 bytes
36 // * serialized_message is the serialized version of sample (using ToString)
38 // NB: the file will never leave the device so message_size will be written
39 // with the architecture's endianness.
40 bool WriteMetricToFile(const MetricSample& sample, const std::string& filename);
42 // Maximum length of a serialized message
43 static const int kMessageMaxLength = 1024;
45 } // namespace SerializationUtils
46 } // namespace metrics
48 #endif // COMPONENTS_METRICS_SERIALIZATION_SERIALIZATION_UTILS_H_