summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorKonstantin Käfer <mail@kkaefer.com>2014-10-31 16:33:45 -0400
committerKonstantin Käfer <mail@kkaefer.com>2014-10-31 16:33:45 -0400
commita50042349c002dcac2812c0ee046025b36ee45a4 (patch)
tree6e996229aead47a6d9a8f1e2c702454cc2110f56 /src
parent8dda6482fa429e01da087a690ca7d9cde3a7abc0 (diff)
parentffc42cac0232cb4c30ed946717414174fd42de8b (diff)
downloadqtlocation-mapboxgl-a50042349c002dcac2812c0ee046025b36ee45a4.tar.gz
Merge branch 'master' into platform-image
Diffstat (limited to 'src')
-rw-r--r--src/csscolorparser/csscolorparser.cpp15
-rw-r--r--src/geometry/debug_font_buffer.cpp14
-rw-r--r--src/geometry/debug_font_data.hpp (renamed from src/geometry/debug_font.cpp)200
-rw-r--r--src/storage/file_source.cpp6
-rw-r--r--src/util/uv-messenger.c9
-rw-r--r--src/util/uv-worker.c6
6 files changed, 126 insertions, 124 deletions
diff --git a/src/csscolorparser/csscolorparser.cpp b/src/csscolorparser/csscolorparser.cpp
index d52c6280cf..938470f192 100644
--- a/src/csscolorparser/csscolorparser.cpp
+++ b/src/csscolorparser/csscolorparser.cpp
@@ -29,12 +29,12 @@
#include <sstream>
#include <cmath>
#include <algorithm>
-#include <map>
using namespace CSSColorParser;
// http://www.w3.org/TR/css3-color/
-const std::map<std::string, Color> kCSSColorTable = {
+struct NamedColor { const char *const name; const Color color; };
+const NamedColor namedColors[] = {
{ "transparent", { 0, 0, 0, 0 } }, { "aliceblue", { 240, 248, 255, 1 } },
{ "antiquewhite", { 250, 235, 215, 1 } }, { "aqua", { 0, 255, 255, 1 } },
{ "aquamarine", { 127, 255, 212, 1 } }, { "azure", { 240, 255, 255, 1 } },
@@ -111,6 +111,8 @@ const std::map<std::string, Color> kCSSColorTable = {
{ "yellow", { 255, 255, 0, 1 } }, { "yellowgreen", { 154, 205, 50, 1 } }
};
+const size_t namedColorCount = sizeof (namedColors) / sizeof (NamedColor);
+
template <typename T>
uint8_t clamp_css_byte(T i) { // Clamp to integer 0 .. 255.
@@ -187,10 +189,11 @@ Color CSSColorParser::parse(const std::string& css_str) {
// Convert to lowercase.
std::transform(str.begin(), str.end(), str.begin(), ::tolower);
- // Color keywords (and transparent) lookup.
- auto it = kCSSColorTable.find(str);
- if (it != kCSSColorTable.end()) {
- return it->second;
+
+ for (size_t i = 0; i < namedColorCount; i++) {
+ if (str == namedColors[i].name) {
+ return namedColors[i].color;
+ }
}
// #abc and #abc123 syntax.
diff --git a/src/geometry/debug_font_buffer.cpp b/src/geometry/debug_font_buffer.cpp
index 2a0924a1c4..6c233f88df 100644
--- a/src/geometry/debug_font_buffer.cpp
+++ b/src/geometry/debug_font_buffer.cpp
@@ -3,7 +3,7 @@
#include <cmath>
#include <cstring>
-#include "debug_font.cpp"
+#include "debug_font_data.hpp"
using namespace mbgl;
@@ -12,19 +12,11 @@ void DebugFontBuffer::addText(const char *text, double left, double baseline, do
const size_t len = strlen(text);
for (size_t i = 0; i < len; ++i) {
- if (text[i] < 32 || (unsigned char)(text[i]) > 127) {
+ if (text[i] < 32 || (unsigned char)(text[i]) >= 127) {
continue;
}
- auto it = simplex.find((int)text[i]);
- if (it == simplex.end()) {
- continue;
- }
-
- const glyph& glyph = it->second;
- if (!glyph.width) {
- continue;
- }
+ const glyph& glyph = simplex[text[i] - 32];
int16_t prev_x = -1, prev_y = -1, prev = false;
for (int32_t j = 0; j < glyph.length; j += 2) {
diff --git a/src/geometry/debug_font.cpp b/src/geometry/debug_font_data.hpp
index 8ee9f6811f..26c54cb480 100644
--- a/src/geometry/debug_font.cpp
+++ b/src/geometry/debug_font_data.hpp
@@ -1,3 +1,5 @@
+// This is an implementation file, so omit include guards.
+
#include <cstdint>
#include <map>
@@ -97,11 +99,6 @@ const int8_t simplex_93[] = { 5, 25, 7, 24, 8, 23, 9, 21, 9, 19, 8, 17, 7, 16, 6
const int8_t simplex_94[] = { 3, 6, 3, 8, 4, 11, 6, 12, 8, 12, 10, 11, 14, 8, 16, 7, 18, 7, 20, 8, 21, 10, -1, -1, 3, 8, 4, 10, 6, 11, 8, 11, 10, 10, 14, 7, 16, 6, 18, 6, 20, 7, 21, 10, 21, 12 };
struct glyph {
- glyph() : width(0), length(0), data(nullptr) { }
- glyph(uint8_t width_, uint8_t length_, const int8_t *data_)
- : width(width_),
- length(length_),
- data(data_) {}
uint8_t width;
uint8_t length;
const int8_t *data;
@@ -109,100 +106,101 @@ struct glyph {
// Font data From Hershey Simplex Font
// http://paulbourke.net/dataformats/hershey/
-const std::map<char, glyph> simplex = {
- { ' ', { 16, 0, nullptr } },
- { '!', { 10, sizeof(simplex_1), simplex_1 } },
- { '"', { 16, sizeof(simplex_2), simplex_2 } },
- { '#', { 21, sizeof(simplex_3), simplex_3 } },
- { '$', { 20, sizeof(simplex_4), simplex_4 } },
- { '%', { 24, sizeof(simplex_5), simplex_5 } },
- { '&', { 26, sizeof(simplex_6), simplex_6 } },
- { '\'', { 10, sizeof(simplex_7), simplex_7 } },
- { '(', { 14, sizeof(simplex_8), simplex_8 } },
- { ')', { 14, sizeof(simplex_9), simplex_9 } },
- { '*', { 16, sizeof(simplex_10), simplex_10 } },
- { '+', { 26, sizeof(simplex_11), simplex_11 } },
- { ',', { 10, sizeof(simplex_12), simplex_12 } },
- { '-', { 26, sizeof(simplex_13), simplex_13 } },
- { '.', { 10, sizeof(simplex_14), simplex_14 } },
- { '/', { 22, sizeof(simplex_15), simplex_15 } },
- { '0', { 20, sizeof(simplex_16), simplex_16 } },
- { '1', { 20, sizeof(simplex_17), simplex_17 } },
- { '2', { 20, sizeof(simplex_18), simplex_18 } },
- { '3', { 20, sizeof(simplex_19), simplex_19 } },
- { '4', { 20, sizeof(simplex_20), simplex_20 } },
- { '5', { 20, sizeof(simplex_21), simplex_21 } },
- { '6', { 20, sizeof(simplex_22), simplex_22 } },
- { '7', { 20, sizeof(simplex_23), simplex_23 } },
- { '8', { 20, sizeof(simplex_24), simplex_24 } },
- { '9', { 20, sizeof(simplex_25), simplex_25 } },
- { ':', { 10, sizeof(simplex_26), simplex_26 } },
- { ';', { 10, sizeof(simplex_27), simplex_27 } },
- { '<', { 24, sizeof(simplex_28), simplex_28 } },
- { '=', { 26, sizeof(simplex_29), simplex_29 } },
- { '>', { 24, sizeof(simplex_30), simplex_30 } },
- { '?', { 18, sizeof(simplex_31), simplex_31 } },
- { '@', { 27, sizeof(simplex_32), simplex_32 } },
- { 'A', { 18, sizeof(simplex_33), simplex_33 } },
- { 'B', { 21, sizeof(simplex_34), simplex_34 } },
- { 'C', { 21, sizeof(simplex_35), simplex_35 } },
- { 'D', { 21, sizeof(simplex_36), simplex_36 } },
- { 'E', { 19, sizeof(simplex_37), simplex_37 } },
- { 'F', { 18, sizeof(simplex_38), simplex_38 } },
- { 'G', { 21, sizeof(simplex_39), simplex_39 } },
- { 'H', { 22, sizeof(simplex_40), simplex_40 } },
- { 'I', { 8, sizeof(simplex_41), simplex_41 } },
- { 'J', { 16, sizeof(simplex_42), simplex_42 } },
- { 'K', { 21, sizeof(simplex_43), simplex_43 } },
- { 'L', { 17, sizeof(simplex_44), simplex_44 } },
- { 'M', { 24, sizeof(simplex_45), simplex_45 } },
- { 'N', { 22, sizeof(simplex_46), simplex_46 } },
- { 'O', { 22, sizeof(simplex_47), simplex_47 } },
- { 'P', { 21, sizeof(simplex_48), simplex_48 } },
- { 'Q', { 22, sizeof(simplex_49), simplex_49 } },
- { 'R', { 21, sizeof(simplex_50), simplex_50 } },
- { 'S', { 20, sizeof(simplex_51), simplex_51 } },
- { 'T', { 16, sizeof(simplex_52), simplex_52 } },
- { 'U', { 22, sizeof(simplex_53), simplex_53 } },
- { 'V', { 18, sizeof(simplex_54), simplex_54 } },
- { 'W', { 24, sizeof(simplex_55), simplex_55 } },
- { 'X', { 20, sizeof(simplex_56), simplex_56 } },
- { 'Y', { 18, sizeof(simplex_57), simplex_57 } },
- { 'Z', { 20, sizeof(simplex_58), simplex_58 } },
- { '[', { 14, sizeof(simplex_59), simplex_59 } },
- { '\\', { 14, sizeof(simplex_60), simplex_60 } },
- { ']', { 14, sizeof(simplex_61), simplex_61 } },
- { '^', { 16, sizeof(simplex_62), simplex_62 } },
- { '_', { 16, sizeof(simplex_63), simplex_63 } },
- { '`', { 10, sizeof(simplex_64), simplex_64 } },
- { 'a', { 19, sizeof(simplex_65), simplex_65 } },
- { 'b', { 19, sizeof(simplex_66), simplex_66 } },
- { 'c', { 18, sizeof(simplex_67), simplex_67 } },
- { 'd', { 19, sizeof(simplex_68), simplex_68 } },
- { 'e', { 18, sizeof(simplex_69), simplex_69 } },
- { 'f', { 12, sizeof(simplex_70), simplex_70 } },
- { 'g', { 19, sizeof(simplex_71), simplex_71 } },
- { 'h', { 19, sizeof(simplex_72), simplex_72 } },
- { 'i', { 8, sizeof(simplex_73), simplex_73 } },
- { 'j', { 10, sizeof(simplex_74), simplex_74 } },
- { 'k', { 17, sizeof(simplex_75), simplex_75 } },
- { 'l', { 8, sizeof(simplex_76), simplex_76 } },
- { 'm', { 30, sizeof(simplex_77), simplex_77 } },
- { 'n', { 19, sizeof(simplex_78), simplex_78 } },
- { 'o', { 19, sizeof(simplex_79), simplex_79 } },
- { 'p', { 19, sizeof(simplex_80), simplex_80 } },
- { 'q', { 19, sizeof(simplex_81), simplex_81 } },
- { 'r', { 13, sizeof(simplex_82), simplex_82 } },
- { 's', { 17, sizeof(simplex_83), simplex_83 } },
- { 't', { 12, sizeof(simplex_84), simplex_84 } },
- { 'u', { 19, sizeof(simplex_85), simplex_85 } },
- { 'v', { 16, sizeof(simplex_86), simplex_86 } },
- { 'w', { 22, sizeof(simplex_87), simplex_87 } },
- { 'x', { 17, sizeof(simplex_88), simplex_88 } },
- { 'y', { 16, sizeof(simplex_89), simplex_89 } },
- { 'z', { 17, sizeof(simplex_90), simplex_90 } },
- { '{', { 14, sizeof(simplex_91), simplex_91 } },
- { '|', { 8, sizeof(simplex_92), simplex_92 } },
- { '}', { 14, sizeof(simplex_93), simplex_93 } },
- { '~', { 24, sizeof(simplex_94), simplex_94 } }
+
+const glyph simplex[] = {
+ /* 32 */ { 16, 0, nullptr },
+ /* 33 ! */ { 10, sizeof(simplex_1), simplex_1 },
+ /* 34 " */ { 16, sizeof(simplex_2), simplex_2 },
+ /* 35 # */ { 21, sizeof(simplex_3), simplex_3 },
+ /* 36 $ */ { 20, sizeof(simplex_4), simplex_4 },
+ /* 37 % */ { 24, sizeof(simplex_5), simplex_5 },
+ /* 38 & */ { 26, sizeof(simplex_6), simplex_6 },
+ /* 39 ' */ { 10, sizeof(simplex_7), simplex_7 },
+ /* 40 ( */ { 14, sizeof(simplex_8), simplex_8 },
+ /* 41 ) */ { 14, sizeof(simplex_9), simplex_9 },
+ /* 42 * */ { 16, sizeof(simplex_10), simplex_10 },
+ /* 43 + */ { 26, sizeof(simplex_11), simplex_11 },
+ /* 44 , */ { 10, sizeof(simplex_12), simplex_12 },
+ /* 45 - */ { 26, sizeof(simplex_13), simplex_13 },
+ /* 46 . */ { 10, sizeof(simplex_14), simplex_14 },
+ /* 47 / */ { 22, sizeof(simplex_15), simplex_15 },
+ /* 48 0 */ { 20, sizeof(simplex_16), simplex_16 },
+ /* 49 1 */ { 20, sizeof(simplex_17), simplex_17 },
+ /* 50 2 */ { 20, sizeof(simplex_18), simplex_18 },
+ /* 51 3 */ { 20, sizeof(simplex_19), simplex_19 },
+ /* 52 4 */ { 20, sizeof(simplex_20), simplex_20 },
+ /* 53 5 */ { 20, sizeof(simplex_21), simplex_21 },
+ /* 54 6 */ { 20, sizeof(simplex_22), simplex_22 },
+ /* 55 7 */ { 20, sizeof(simplex_23), simplex_23 },
+ /* 56 8 */ { 20, sizeof(simplex_24), simplex_24 },
+ /* 57 9 */ { 20, sizeof(simplex_25), simplex_25 },
+ /* 58 : */ { 10, sizeof(simplex_26), simplex_26 },
+ /* 59 ; */ { 10, sizeof(simplex_27), simplex_27 },
+ /* 60 < */ { 24, sizeof(simplex_28), simplex_28 },
+ /* 61 = */ { 26, sizeof(simplex_29), simplex_29 },
+ /* 62 > */ { 24, sizeof(simplex_30), simplex_30 },
+ /* 63 ? */ { 18, sizeof(simplex_31), simplex_31 },
+ /* 64 @ */ { 27, sizeof(simplex_32), simplex_32 },
+ /* 65 A */ { 18, sizeof(simplex_33), simplex_33 },
+ /* 66 B */ { 21, sizeof(simplex_34), simplex_34 },
+ /* 67 C */ { 21, sizeof(simplex_35), simplex_35 },
+ /* 68 D */ { 21, sizeof(simplex_36), simplex_36 },
+ /* 69 E */ { 19, sizeof(simplex_37), simplex_37 },
+ /* 70 F */ { 18, sizeof(simplex_38), simplex_38 },
+ /* 71 G */ { 21, sizeof(simplex_39), simplex_39 },
+ /* 72 H */ { 22, sizeof(simplex_40), simplex_40 },
+ /* 73 I */ { 8, sizeof(simplex_41), simplex_41 },
+ /* 74 J */ { 16, sizeof(simplex_42), simplex_42 },
+ /* 75 K */ { 21, sizeof(simplex_43), simplex_43 },
+ /* 76 L */ { 17, sizeof(simplex_44), simplex_44 },
+ /* 77 M */ { 24, sizeof(simplex_45), simplex_45 },
+ /* 78 N */ { 22, sizeof(simplex_46), simplex_46 },
+ /* 79 O */ { 22, sizeof(simplex_47), simplex_47 },
+ /* 80 P */ { 21, sizeof(simplex_48), simplex_48 },
+ /* 81 Q */ { 22, sizeof(simplex_49), simplex_49 },
+ /* 82 R */ { 21, sizeof(simplex_50), simplex_50 },
+ /* 83 S */ { 20, sizeof(simplex_51), simplex_51 },
+ /* 84 T */ { 16, sizeof(simplex_52), simplex_52 },
+ /* 85 U */ { 22, sizeof(simplex_53), simplex_53 },
+ /* 86 V */ { 18, sizeof(simplex_54), simplex_54 },
+ /* 87 W */ { 24, sizeof(simplex_55), simplex_55 },
+ /* 88 X */ { 20, sizeof(simplex_56), simplex_56 },
+ /* 89 Y */ { 18, sizeof(simplex_57), simplex_57 },
+ /* 90 Z */ { 20, sizeof(simplex_58), simplex_58 },
+ /* 91 [ */ { 14, sizeof(simplex_59), simplex_59 },
+ /* 92 \ */ { 14, sizeof(simplex_60), simplex_60 },
+ /* 93 ] */ { 14, sizeof(simplex_61), simplex_61 },
+ /* 94 ^ */ { 16, sizeof(simplex_62), simplex_62 },
+ /* 95 _ */ { 16, sizeof(simplex_63), simplex_63 },
+ /* 96 ` */ { 10, sizeof(simplex_64), simplex_64 },
+ /* 97 a */ { 19, sizeof(simplex_65), simplex_65 },
+ /* 98 b */ { 19, sizeof(simplex_66), simplex_66 },
+ /* 99 c */ { 18, sizeof(simplex_67), simplex_67 },
+ /* 100 d */ { 19, sizeof(simplex_68), simplex_68 },
+ /* 101 e */ { 18, sizeof(simplex_69), simplex_69 },
+ /* 102 f */ { 12, sizeof(simplex_70), simplex_70 },
+ /* 103 g */ { 19, sizeof(simplex_71), simplex_71 },
+ /* 104 h */ { 19, sizeof(simplex_72), simplex_72 },
+ /* 105 i */ { 8, sizeof(simplex_73), simplex_73 },
+ /* 106 j */ { 10, sizeof(simplex_74), simplex_74 },
+ /* 107 k */ { 17, sizeof(simplex_75), simplex_75 },
+ /* 108 l */ { 8, sizeof(simplex_76), simplex_76 },
+ /* 109 m */ { 30, sizeof(simplex_77), simplex_77 },
+ /* 110 n */ { 19, sizeof(simplex_78), simplex_78 },
+ /* 111 o */ { 19, sizeof(simplex_79), simplex_79 },
+ /* 112 p */ { 19, sizeof(simplex_80), simplex_80 },
+ /* 113 q */ { 19, sizeof(simplex_81), simplex_81 },
+ /* 114 r */ { 13, sizeof(simplex_82), simplex_82 },
+ /* 115 s */ { 17, sizeof(simplex_83), simplex_83 },
+ /* 116 t */ { 12, sizeof(simplex_84), simplex_84 },
+ /* 117 u */ { 19, sizeof(simplex_85), simplex_85 },
+ /* 118 v */ { 16, sizeof(simplex_86), simplex_86 },
+ /* 119 w */ { 22, sizeof(simplex_87), simplex_87 },
+ /* 120 x */ { 17, sizeof(simplex_88), simplex_88 },
+ /* 121 y */ { 16, sizeof(simplex_89), simplex_89 },
+ /* 122 z */ { 17, sizeof(simplex_90), simplex_90 },
+ /* 123 { */ { 14, sizeof(simplex_91), simplex_91 },
+ /* 124 | */ { 8, sizeof(simplex_92), simplex_92 },
+ /* 125 } */ { 14, sizeof(simplex_93), simplex_93 },
+ /* 126 ~ */ { 24, sizeof(simplex_94), simplex_94 },
};
diff --git a/src/storage/file_source.cpp b/src/storage/file_source.cpp
index 70b4abe4c7..a67f57dac4 100644
--- a/src/storage/file_source.cpp
+++ b/src/storage/file_source.cpp
@@ -23,9 +23,9 @@ FileSource::FileSource(uv_loop_t *loop_, const std::string &path)
FileSource::~FileSource() {
assert(thread_id == uv_thread_self());
- uv_messenger_stop(queue);
- // NOTE: We don't need to delete the messenger since it will be deleted by the
- // uv_messenger_stop() function.
+ uv_messenger_stop(queue, [](uv_messenger_t *msgr) {
+ delete msgr;
+ });
util::ptr<BaseRequest> req;
diff --git a/src/util/uv-messenger.c b/src/util/uv-messenger.c
index bfa1565768..935b6f1c41 100644
--- a/src/util/uv-messenger.c
+++ b/src/util/uv-messenger.c
@@ -2,6 +2,7 @@
#include <mbgl/util/queue.h>
#include <stdlib.h>
+#include <assert.h>
typedef struct {
void *data;
@@ -46,6 +47,7 @@ int uv_messenger_init(uv_loop_t *loop, uv_messenger_t *msgr, uv_messenger_cb cal
}
msgr->callback = callback;
+ msgr->stop_callback = NULL;
QUEUE_INIT(&msgr->queue);
@@ -73,9 +75,12 @@ void uv_messenger_unref(uv_messenger_t *msgr) {
}
void uv__messenger_stop_callback(uv_handle_t *handle) {
- free((uv_messenger_t *)handle->data);
+ uv_messenger_t *msgr = (uv_messenger_t *)handle->data;
+ msgr->stop_callback(msgr);
}
-void uv_messenger_stop(uv_messenger_t *msgr) {
+void uv_messenger_stop(uv_messenger_t *msgr, uv_messenger_stop_cb stop_callback) {
+ assert(!msgr->stop_callback);
+ msgr->stop_callback = stop_callback;
uv_close((uv_handle_t *)&msgr->async, uv__messenger_stop_callback);
}
diff --git a/src/util/uv-worker.c b/src/util/uv-worker.c
index 8b0cc6dda7..d2aa908019 100644
--- a/src/util/uv-worker.c
+++ b/src/util/uv-worker.c
@@ -18,6 +18,10 @@ struct uv__worker_thread_s {
uv_thread_t thread;
};
+void uv__worker_free_messenger(uv_messenger_t *msgr) {
+ free(msgr);
+}
+
void uv__worker_thread_finished(uv__worker_thread_t *worker_thread) {
uv_worker_t *worker = worker_thread->worker;
@@ -35,7 +39,7 @@ void uv__worker_thread_finished(uv__worker_thread_t *worker_thread) {
worker->count--;
if (worker->count == 0) {
uv_chan_destroy(&worker->chan);
- uv_messenger_stop(worker->msgr);
+ uv_messenger_stop(worker->msgr, uv__worker_free_messenger);
if (worker->close_cb) {
worker->close_cb(worker);
}