aboutsummaryrefslogtreecommitdiffstats
path: root/WireGuard
diff options
context:
space:
mode:
authorJason A. Donenfeld <Jason@zx2c4.com>2019-01-09 11:59:43 -0800
committerRoopesh Chander <roop@roopc.net>2019-01-14 14:52:36 +0530
commitba731e009999f259b2a50a60035d465b15f9f18c (patch)
tree4b6be698e4c74623804ccbcb16c724c04bacc205 /WireGuard
parentSyntax highlighter color updates (diff)
downloadwireguard-apple-ba731e009999f259b2a50a60035d465b15f9f18c.tar.xz
wireguard-apple-ba731e009999f259b2a50a60035d465b15f9f18c.zip
Resync highlighter
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
Diffstat (limited to 'WireGuard')
-rw-r--r--WireGuard/WireGuard/UI/macOS/View/ConfTextStorage.swift2
-rw-r--r--WireGuard/WireGuard/UI/macOS/highlighter.c91
-rw-r--r--WireGuard/WireGuard/UI/macOS/highlighter.h3
3 files changed, 42 insertions, 54 deletions
diff --git a/WireGuard/WireGuard/UI/macOS/View/ConfTextStorage.swift b/WireGuard/WireGuard/UI/macOS/View/ConfTextStorage.swift
index 223d1a5..5ed3e68 100644
--- a/WireGuard/WireGuard/UI/macOS/View/ConfTextStorage.swift
+++ b/WireGuard/WireGuard/UI/macOS/View/ConfTextStorage.swift
@@ -54,7 +54,7 @@ class ConfTextStorage: NSTextStorage {
.foregroundColor: theme.sections,
.font: boldFont
],
- HighlightKeytype.rawValue: [
+ HighlightField.rawValue: [
.foregroundColor: theme.keyType,
.font: boldFont
],
diff --git a/WireGuard/WireGuard/UI/macOS/highlighter.c b/WireGuard/WireGuard/UI/macOS/highlighter.c
index ff8bf06..3c5cd98 100644
--- a/WireGuard/WireGuard/UI/macOS/highlighter.c
+++ b/WireGuard/WireGuard/UI/macOS/highlighter.c
@@ -120,47 +120,15 @@ static bool is_valid_ipv6(string_span_t s)
return true;
}
-static bool is_valid_u16(string_span_t s)
-{
- uint32_t val = 0;
-
- if (s.len > 5 || !s.len)
- return false;
-
- for (size_t i = 0; i < s.len; ++i) {
- if (!isdigit(s.s[i]))
- return false;
- val = 10 * val + s.s[i] - '0';
- }
- return val <= 65535;
-}
-
-static bool is_valid_port(string_span_t s)
-{
- return is_valid_u16(s);
-}
-
-static bool is_valid_mtu(string_span_t s)
-{
- return is_valid_u16(s);
-}
-
-static bool is_valid_persistentkeepalive(string_span_t s)
-{
- if (s.len == 3 && !memcmp(s.s, "off", 3))
- return true;
- return is_valid_u16(s);
-}
-
-#ifndef MOBILE_WGQUICK_SUBSET
-static bool is_valid_u32(string_span_t s)
+static bool is_valid_uint(string_span_t s, bool support_hex, uint64_t min, uint64_t max)
{
uint64_t val = 0;
+ /* Bound this around 32 bits, so that we don't have to write overflow logic. */
if (s.len > 10 || !s.len)
return false;
- if (s.len > 2 && s.s[0] == '0' && s.s[1] == 'x') {
+ if (support_hex && s.len > 2 && s.s[0] == '0' && s.s[1] == 'x') {
for (size_t i = 2; i < s.len; ++i) {
if (s.s[i] - '0' < 10)
val = 16 * val + (s.s[i] - '0');
@@ -176,14 +144,33 @@ static bool is_valid_u32(string_span_t s)
val = 10 * val + s.s[i] - '0';
}
}
- return val <= 4294967295U;
+ return val <= max && val >= min;
+}
+
+static bool is_valid_port(string_span_t s)
+{
+ return is_valid_uint(s, false, 0, 65535);
+}
+
+static bool is_valid_mtu(string_span_t s)
+{
+ return is_valid_uint(s, false, 576, 65535);
+}
+
+static bool is_valid_persistentkeepalive(string_span_t s)
+{
+ if (s.len == 3 && !memcmp(s.s, "off", 3))
+ return true;
+ return is_valid_uint(s, false, 0, 65535);
}
+#ifndef MOBILE_WGQUICK_SUBSET
+
static bool is_valid_fwmark(string_span_t s)
{
if (s.len == 3 && !memcmp(s.s, "off", 3))
return true;
- return is_valid_u32(s);
+ return is_valid_uint(s, true, 0, 4294967295);
}
static bool is_valid_table(string_span_t s)
@@ -196,7 +183,7 @@ static bool is_valid_table(string_span_t s)
* fread_id_name does no validation aside from this. */
if (s.len < 512)
return true;
- return is_valid_u32(s);
+ return is_valid_uint(s, false, 0, 4294967295);
}
static bool is_valid_saveconfig(string_span_t s)
@@ -301,7 +288,7 @@ static bool is_valid_dns(string_span_t s)
return is_valid_ipv4(s) || is_valid_ipv6(s);
}
-enum keytype {
+enum field {
InterfaceSection,
PrivateKey,
ListenPort,
@@ -325,7 +312,7 @@ enum keytype {
Invalid
};
-static enum keytype section_for_keytype(enum keytype t)
+static enum field section_for_field(enum field t)
{
if (t > InterfaceSection && t < PeerSection)
return InterfaceSection;
@@ -334,7 +321,7 @@ static enum keytype section_for_keytype(enum keytype t)
return Invalid;
}
-static enum keytype get_keytype(string_span_t s)
+static enum field get_field(string_span_t s)
{
#define check_enum(t) do { if (s.len == strlen(#t) && !strncasecmp(#t, s.s, s.len)) return t; } while (0)
check_enum(PrivateKey);
@@ -360,7 +347,7 @@ static enum keytype get_keytype(string_span_t s)
#undef check_enum
}
-static enum keytype get_sectiontype(string_span_t s)
+static enum field get_sectiontype(string_span_t s)
{
if (s.len == 6 && !strncasecmp("[Peer]", s.s, 6))
return PeerSection;
@@ -406,7 +393,7 @@ static bool append_highlight_span(struct highlight_span_array *a, const char *o,
return true;
}
-static void highlight_multivalue_value(struct highlight_span_array *ret, const string_span_t parent, const string_span_t s, enum keytype section)
+static void highlight_multivalue_value(struct highlight_span_array *ret, const string_span_t parent, const string_span_t s, enum field section)
{
switch (section) {
case DNS:
@@ -438,7 +425,7 @@ static void highlight_multivalue_value(struct highlight_span_array *ret, const s
}
}
-static void highlight_multivalue(struct highlight_span_array *ret, const string_span_t parent, const string_span_t s, enum keytype section)
+static void highlight_multivalue(struct highlight_span_array *ret, const string_span_t parent, const string_span_t s, enum field section)
{
string_span_t current_span = { s.s, 0 };
size_t len_at_last_space = 0;
@@ -466,7 +453,7 @@ static void highlight_multivalue(struct highlight_span_array *ret, const string_
ret->spans[ret->len - 1].type = HighlightError;
}
-static void highlight_value(struct highlight_span_array *ret, const string_span_t parent, const string_span_t s, enum keytype section)
+static void highlight_value(struct highlight_span_array *ret, const string_span_t parent, const string_span_t s, enum field section)
{
switch (section) {
case PrivateKey:
@@ -535,7 +522,7 @@ struct highlight_span *highlight_config(const char *config)
struct highlight_span_array ret = { 0 };
const string_span_t s = { config, strlen(config) };
string_span_t current_span = { s.s, 0 };
- enum keytype current_section = Invalid, current_keytype = Invalid;
+ enum field current_section = Invalid, current_field = Invalid;
enum { OnNone, OnKey, OnValue, OnComment, OnSection } state = OnNone;
size_t len_at_last_space = 0, equals_location = 0;
@@ -548,7 +535,7 @@ struct highlight_span *highlight_config(const char *config)
if (current_span.len) {
append_highlight_span(&ret, s.s, (string_span_t){ s.s + equals_location, 1 }, HighlightDelimiter);
current_span.len = len_at_last_space;
- highlight_value(&ret, s, current_span, current_keytype);
+ highlight_value(&ret, s, current_span, current_field);
} else {
append_highlight_span(&ret, s.s, (string_span_t){ s.s + equals_location, 1 }, HighlightError);
}
@@ -562,7 +549,7 @@ struct highlight_span *highlight_config(const char *config)
if (i == s.len)
break;
len_at_last_space = 0;
- current_keytype = Invalid;
+ current_field = Invalid;
if (s.s[i] == '#') {
current_span = (string_span_t){ s.s + i, 1 };
state = OnComment;
@@ -579,12 +566,12 @@ struct highlight_span *highlight_config(const char *config)
++current_span.len;
} else if (s.s[i] == '=' && state == OnKey) {
current_span.len = len_at_last_space;
- current_keytype = get_keytype(current_span);
- enum keytype section = section_for_keytype(current_keytype);
- if (section == Invalid || current_keytype == Invalid || section != current_section)
+ current_field = get_field(current_span);
+ enum field section = section_for_field(current_field);
+ if (section == Invalid || current_field == Invalid || section != current_section)
append_highlight_span(&ret, s.s, current_span, HighlightError);
else
- append_highlight_span(&ret, s.s, current_span, HighlightKeytype);
+ append_highlight_span(&ret, s.s, current_span, HighlightField);
equals_location = i;
current_span = (string_span_t){ s.s + i + 1, 0 };
state = OnValue;
diff --git a/WireGuard/WireGuard/UI/macOS/highlighter.h b/WireGuard/WireGuard/UI/macOS/highlighter.h
index 4e5fa4c..885db2d 100644
--- a/WireGuard/WireGuard/UI/macOS/highlighter.h
+++ b/WireGuard/WireGuard/UI/macOS/highlighter.h
@@ -4,10 +4,11 @@
*/
#include <sys/types.h>
+#define MOBILE_WGQUICK_SUBSET
enum highlight_type {
HighlightSection,
- HighlightKeytype,
+ HighlightField,
HighlightPrivateKey,
HighlightPublicKey,
HighlightPresharedKey,