| Index: components/physical_web/eddystone/eddystone_encoder.h
|
| diff --git a/components/physical_web/eddystone/eddystone_encoder.h b/components/physical_web/eddystone/eddystone_encoder.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..eaff749733cd7a8cc64ba064b380e5fcf46c33b6
|
| --- /dev/null
|
| +++ b/components/physical_web/eddystone/eddystone_encoder.h
|
| @@ -0,0 +1,34 @@
|
| +// Copyright 2017 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef COMPONENTS_PHYSICAL_WEB_EDDYSTONE_EDDYSTONE_ENCODER_H_
|
| +#define COMPONENTS_PHYSICAL_WEB_EDDYSTONE_EDDYSTONE_ENCODER_H_
|
| +
|
| +#include <string>
|
| +#include <vector>
|
| +
|
| +namespace physical_web {
|
| +
|
| +const size_t kEmptyUrl = static_cast<size_t>(-1);
|
| +const size_t kInvalidUrl = static_cast<size_t>(-2);
|
| +const size_t kInvalidFormat = static_cast<size_t>(-3);
|
| +const size_t kNullEncodedUrl = static_cast<size_t>(-4);
|
| +
|
| +/*
|
| + * EncodeUrl takes a URL in the form of a std::string and
|
| + * a pointer to a uint8_t vector to populate with the eddystone
|
| + * encoding of the URL.
|
| + * Returns:
|
| + * kEmptyUrl If the URL parameter is empty.
|
| + * kInvalidUrl If the URL parameter is not a valid URL.
|
| + * kInvalidFormat If the URL parameter is not a standard HTTPS/HTTP URL.
|
| + * kNullEncodedUrl If the encoded_url vector is NULL.
|
| + * Length of encoded URL.
|
| + * Eddystone spec can be found here:
|
| + * https://github.com/google/eddystone/blob/master/protocol-specification.md
|
| + */
|
| +size_t EncodeUrl(const std::string& url, std::vector<uint8_t>* encoded_url);
|
| +}
|
| +
|
| +#endif // COMPONENTS_PHYSICAL_WEB_EDDYSTONE_EDDYSTONE_ENCODER_H_
|
|
|