mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-12 21:32:40 +00:00
Merge pull request #892 from zed-industries/syntax-theme-fixes
Syntax theme fixes
This commit is contained in:
commit
f881c2aa92
17 changed files with 231 additions and 75 deletions
|
@ -692,33 +692,88 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"syntax": {
|
"syntax": {
|
||||||
"keyword": "#4f8ff7",
|
"primary": {
|
||||||
"function": "#f9da82",
|
"color": "#d5d5d5",
|
||||||
"string": "#f99d5f",
|
"weight": "normal"
|
||||||
"type": "#3eeeda",
|
},
|
||||||
"number": "#aeef4b",
|
"comment": {
|
||||||
"comment": "#aaaaaa",
|
"color": "#aaaaaa",
|
||||||
"property": "#4f8ff7",
|
"weight": "normal"
|
||||||
"variant": "#53c1f5",
|
},
|
||||||
"constant": "#d5d5d5",
|
"punctuation": {
|
||||||
|
"color": "#c6c6c6",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"constant": {
|
||||||
|
"color": "#d5d5d5",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"keyword": {
|
||||||
|
"color": "#4f8ff7",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"function": {
|
||||||
|
"color": "#f9da82",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"type": {
|
||||||
|
"color": "#3eeeda",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"variant": {
|
||||||
|
"color": "#53c1f5",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"property": {
|
||||||
|
"color": "#4f8ff7",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"enum": {
|
||||||
|
"color": "#ee670a",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"operator": {
|
||||||
|
"color": "#ee670a",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"string": {
|
||||||
|
"color": "#f99d5f",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"number": {
|
||||||
|
"color": "#aeef4b",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"boolean": {
|
||||||
|
"color": "#aeef4b",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"predictive": {
|
||||||
|
"color": "#808080",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
"title": {
|
"title": {
|
||||||
"color": "#de900c",
|
"color": "#de900c",
|
||||||
"weight": "bold"
|
"weight": "bold"
|
||||||
},
|
},
|
||||||
"emphasis": "#4f8ff7",
|
"emphasis": {
|
||||||
"emphasis_strong": {
|
"color": "#4f8ff7",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"emphasis.strong": {
|
||||||
"color": "#4f8ff7",
|
"color": "#4f8ff7",
|
||||||
"weight": "bold"
|
"weight": "bold"
|
||||||
},
|
},
|
||||||
"link_uri": {
|
"link_uri": {
|
||||||
"color": "#79ba16",
|
"color": "#79ba16",
|
||||||
|
"weight": "normal",
|
||||||
"underline": true
|
"underline": true
|
||||||
},
|
},
|
||||||
"link_text": {
|
"link_text": {
|
||||||
"color": "#ee670a",
|
"color": "#ee670a",
|
||||||
|
"weight": "normal",
|
||||||
"italic": true
|
"italic": true
|
||||||
},
|
}
|
||||||
"list_marker": "#c6c6c6"
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"project_diagnostics": {
|
"project_diagnostics": {
|
||||||
|
|
|
@ -692,33 +692,88 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"syntax": {
|
"syntax": {
|
||||||
"keyword": "#1819a1",
|
"primary": {
|
||||||
"function": "#bb550e",
|
"color": "#1c1c1c",
|
||||||
"string": "#eb2d2d",
|
"weight": "normal"
|
||||||
"type": "#a8820e",
|
},
|
||||||
"number": "#484bed",
|
"comment": {
|
||||||
"comment": "#717171",
|
"color": "#717171",
|
||||||
"property": "#106c4e",
|
"weight": "normal"
|
||||||
"variant": "#97142a",
|
},
|
||||||
"constant": "#1c1c1c",
|
"punctuation": {
|
||||||
|
"color": "#555555",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"constant": {
|
||||||
|
"color": "#1c1c1c",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"keyword": {
|
||||||
|
"color": "#1819a1",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"function": {
|
||||||
|
"color": "#bb550e",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"type": {
|
||||||
|
"color": "#a8820e",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"variant": {
|
||||||
|
"color": "#97142a",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"property": {
|
||||||
|
"color": "#106c4e",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"enum": {
|
||||||
|
"color": "#eb2d2d",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"operator": {
|
||||||
|
"color": "#eb2d2d",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"string": {
|
||||||
|
"color": "#eb2d2d",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"number": {
|
||||||
|
"color": "#484bed",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"boolean": {
|
||||||
|
"color": "#eb2d2d",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"predictive": {
|
||||||
|
"color": "#808080",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
"title": {
|
"title": {
|
||||||
"color": "#1096d3",
|
"color": "#1096d3",
|
||||||
"weight": "bold"
|
"weight": "bold"
|
||||||
},
|
},
|
||||||
"emphasis": "#484bed",
|
"emphasis": {
|
||||||
"emphasis_strong": {
|
"color": "#484bed",
|
||||||
|
"weight": "normal"
|
||||||
|
},
|
||||||
|
"emphasis.strong": {
|
||||||
"color": "#484bed",
|
"color": "#484bed",
|
||||||
"weight": "bold"
|
"weight": "bold"
|
||||||
},
|
},
|
||||||
"link_uri": {
|
"link_uri": {
|
||||||
"color": "#79ba16",
|
"color": "#79ba16",
|
||||||
|
"weight": "normal",
|
||||||
"underline": true
|
"underline": true
|
||||||
},
|
},
|
||||||
"link_text": {
|
"link_text": {
|
||||||
"color": "#eb2d2d",
|
"color": "#eb2d2d",
|
||||||
|
"weight": "normal",
|
||||||
"italic": true
|
"italic": true
|
||||||
},
|
}
|
||||||
"list_marker": "#555555"
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"project_diagnostics": {
|
"project_diagnostics": {
|
||||||
|
|
|
@ -51,6 +51,10 @@ impl HighlightMap {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl HighlightId {
|
impl HighlightId {
|
||||||
|
pub fn is_default(&self) -> bool {
|
||||||
|
*self == DEFAULT_SYNTAX_HIGHLIGHT_ID
|
||||||
|
}
|
||||||
|
|
||||||
pub fn style(&self, theme: &SyntaxTheme) -> Option<HighlightStyle> {
|
pub fn style(&self, theme: &SyntaxTheme) -> Option<HighlightStyle> {
|
||||||
theme
|
theme
|
||||||
.highlights
|
.highlights
|
||||||
|
|
|
@ -546,8 +546,10 @@ impl Language {
|
||||||
{
|
{
|
||||||
let end_offset = offset + chunk.text.len();
|
let end_offset = offset + chunk.text.len();
|
||||||
if let Some(highlight_id) = chunk.syntax_highlight_id {
|
if let Some(highlight_id) = chunk.syntax_highlight_id {
|
||||||
|
if !highlight_id.is_default() {
|
||||||
result.push((offset..end_offset, highlight_id));
|
result.push((offset..end_offset, highlight_id));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
offset = end_offset;
|
offset = end_offset;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,7 +56,16 @@
|
||||||
[
|
[
|
||||||
"."
|
"."
|
||||||
";"
|
";"
|
||||||
] @delimiter
|
] @punctuation.delimiter
|
||||||
|
|
||||||
|
[
|
||||||
|
"{"
|
||||||
|
"}"
|
||||||
|
"("
|
||||||
|
")"
|
||||||
|
"["
|
||||||
|
"]"
|
||||||
|
] @punctuation.bracket
|
||||||
|
|
||||||
[
|
[
|
||||||
(string_literal)
|
(string_literal)
|
||||||
|
|
|
@ -86,6 +86,7 @@
|
||||||
"?."
|
"?."
|
||||||
"."
|
"."
|
||||||
","
|
","
|
||||||
|
":"
|
||||||
] @punctuation.delimiter
|
] @punctuation.delimiter
|
||||||
|
|
||||||
[
|
[
|
||||||
|
|
|
@ -12,3 +12,10 @@
|
||||||
(false)
|
(false)
|
||||||
(null)
|
(null)
|
||||||
] @constant
|
] @constant
|
||||||
|
|
||||||
|
[
|
||||||
|
"{"
|
||||||
|
"}"
|
||||||
|
"["
|
||||||
|
"]"
|
||||||
|
] @punctuation.bracket
|
|
@ -12,7 +12,7 @@
|
||||||
(list_marker_star)
|
(list_marker_star)
|
||||||
(list_marker_dot)
|
(list_marker_dot)
|
||||||
(list_marker_parenthesis)
|
(list_marker_parenthesis)
|
||||||
] @list_marker
|
] @punctuation.list_marker
|
||||||
|
|
||||||
[
|
[
|
||||||
(indented_code_block)
|
(indented_code_block)
|
||||||
|
|
|
@ -34,6 +34,20 @@
|
||||||
((identifier) @constant
|
((identifier) @constant
|
||||||
(#match? @constant "^[A-Z][A-Z\\d_]+$"))
|
(#match? @constant "^[A-Z][A-Z\\d_]+$"))
|
||||||
|
|
||||||
|
[
|
||||||
|
"("
|
||||||
|
")"
|
||||||
|
"{"
|
||||||
|
"}"
|
||||||
|
"["
|
||||||
|
"]"
|
||||||
|
] @punctuation.bracket
|
||||||
|
|
||||||
|
(_
|
||||||
|
.
|
||||||
|
"<" @punctuation.bracket
|
||||||
|
">" @punctuation.bracket)
|
||||||
|
|
||||||
[
|
[
|
||||||
"as"
|
"as"
|
||||||
"async"
|
"async"
|
||||||
|
|
|
@ -20,14 +20,18 @@
|
||||||
; Punctuation
|
; Punctuation
|
||||||
;------------
|
;------------
|
||||||
|
|
||||||
"." @punctuation.delimiter
|
[
|
||||||
"," @punctuation.delimiter
|
"."
|
||||||
|
","
|
||||||
|
] @punctuation.delimiter
|
||||||
|
|
||||||
"=" @operator
|
"=" @operator
|
||||||
|
|
||||||
"[" @punctuation.bracket
|
[
|
||||||
"]" @punctuation.bracket
|
"["
|
||||||
"[[" @punctuation.bracket
|
"]"
|
||||||
"]]" @punctuation.bracket
|
"[["
|
||||||
"{" @punctuation.bracket
|
"]]"
|
||||||
"}" @punctuation.bracket
|
"{"
|
||||||
|
"}"
|
||||||
|
] @punctuation.bracket
|
||||||
|
|
|
@ -86,6 +86,7 @@
|
||||||
"?."
|
"?."
|
||||||
"."
|
"."
|
||||||
","
|
","
|
||||||
|
":"
|
||||||
] @punctuation.delimiter
|
] @punctuation.delimiter
|
||||||
|
|
||||||
[
|
[
|
||||||
|
|
|
@ -169,11 +169,19 @@ fn main() {
|
||||||
.detach();
|
.detach();
|
||||||
|
|
||||||
languages.set_language_server_download_dir(zed::ROOT_PATH.clone());
|
languages.set_language_server_download_dir(zed::ROOT_PATH.clone());
|
||||||
|
let languages = Arc::new(languages);
|
||||||
|
|
||||||
|
cx.observe_global::<Settings, _>({
|
||||||
|
let languages = languages.clone();
|
||||||
|
move |settings, _| {
|
||||||
languages.set_theme(&settings.theme.editor.syntax);
|
languages.set_theme(&settings.theme.editor.syntax);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.detach();
|
||||||
cx.set_global(settings);
|
cx.set_global(settings);
|
||||||
|
|
||||||
let app_state = Arc::new(AppState {
|
let app_state = Arc::new(AppState {
|
||||||
languages: Arc::new(languages),
|
languages,
|
||||||
themes,
|
themes,
|
||||||
channel_list,
|
channel_list,
|
||||||
client,
|
client,
|
||||||
|
|
|
@ -37,8 +37,18 @@ export default function editor(theme: Theme) {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const syntax: any = {};
|
||||||
|
for (const syntaxKey in theme.syntax) {
|
||||||
|
const style = theme.syntax[syntaxKey];
|
||||||
|
syntax[syntaxKey] = {
|
||||||
|
color: style.color.value,
|
||||||
|
weight: style.weight.value,
|
||||||
|
underline: style.underline,
|
||||||
|
italic: style.italic,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
// textColor: theme.syntax.primary.color,
|
|
||||||
textColor: theme.syntax.primary.color.value,
|
textColor: theme.syntax.primary.color.value,
|
||||||
background: backgroundColor(theme, 500),
|
background: backgroundColor(theme, 500),
|
||||||
activeLineBackground: theme.editor.line.active.value,
|
activeLineBackground: theme.editor.line.active.value,
|
||||||
|
@ -125,22 +135,6 @@ export default function editor(theme: Theme) {
|
||||||
invalidHintDiagnostic: diagnostic(theme, "muted"),
|
invalidHintDiagnostic: diagnostic(theme, "muted"),
|
||||||
invalidInformationDiagnostic: diagnostic(theme, "muted"),
|
invalidInformationDiagnostic: diagnostic(theme, "muted"),
|
||||||
invalidWarningDiagnostic: diagnostic(theme, "muted"),
|
invalidWarningDiagnostic: diagnostic(theme, "muted"),
|
||||||
syntax: {
|
syntax,
|
||||||
keyword: theme.syntax.keyword.color.value,
|
|
||||||
function: theme.syntax.function.color.value,
|
|
||||||
string: theme.syntax.string.color.value,
|
|
||||||
type: theme.syntax.type.color.value,
|
|
||||||
number: theme.syntax.number.color.value,
|
|
||||||
comment: theme.syntax.comment.color.value,
|
|
||||||
property: theme.syntax.property.color.value,
|
|
||||||
variant: theme.syntax.variant.color.value,
|
|
||||||
constant: theme.syntax.constant.color.value,
|
|
||||||
title: { color: theme.syntax.title.color.value, weight: "bold" },
|
|
||||||
emphasis: theme.textColor.feature.value,
|
|
||||||
"emphasis.strong": { color: theme.textColor.feature.value, weight: "bold" },
|
|
||||||
link_uri: { color: theme.syntax.linkUrl.color.value, underline: true },
|
|
||||||
link_text: { color: theme.syntax.linkText.color.value, italic: true },
|
|
||||||
list_marker: theme.syntax.punctuation.color.value,
|
|
||||||
},
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -202,22 +202,22 @@ const syntax: Syntax = {
|
||||||
weight: fontWeights.bold,
|
weight: fontWeights.bold,
|
||||||
},
|
},
|
||||||
emphasis: {
|
emphasis: {
|
||||||
color: textColor.active,
|
color: textColor.feature,
|
||||||
weight: fontWeights.normal,
|
weight: fontWeights.normal,
|
||||||
},
|
},
|
||||||
emphasisStrong: {
|
"emphasis.strong": {
|
||||||
color: textColor.active,
|
color: textColor.feature,
|
||||||
weight: fontWeights.bold,
|
weight: fontWeights.bold,
|
||||||
},
|
},
|
||||||
linkUrl: {
|
linkUri: {
|
||||||
color: colors.lime[500],
|
color: colors.lime[500],
|
||||||
weight: fontWeights.normal,
|
weight: fontWeights.normal,
|
||||||
// TODO: add underline
|
underline: true,
|
||||||
},
|
},
|
||||||
linkText: {
|
linkText: {
|
||||||
color: colors.orange[500],
|
color: colors.orange[500],
|
||||||
weight: fontWeights.normal,
|
weight: fontWeights.normal,
|
||||||
// TODO: add italic
|
italic: true,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -200,22 +200,22 @@ const syntax: Syntax = {
|
||||||
weight: fontWeights.bold,
|
weight: fontWeights.bold,
|
||||||
},
|
},
|
||||||
emphasis: {
|
emphasis: {
|
||||||
color: textColor.active,
|
color: textColor.feature,
|
||||||
weight: fontWeights.normal,
|
weight: fontWeights.normal,
|
||||||
},
|
},
|
||||||
emphasisStrong: {
|
"emphasis.strong": {
|
||||||
color: textColor.active,
|
color: textColor.feature,
|
||||||
weight: fontWeights.bold,
|
weight: fontWeights.bold,
|
||||||
},
|
},
|
||||||
linkUrl: {
|
linkUri: {
|
||||||
color: colors.lime[500],
|
color: colors.lime[500],
|
||||||
weight: fontWeights.normal,
|
weight: fontWeights.normal,
|
||||||
// TODO: add underline
|
underline: true
|
||||||
},
|
},
|
||||||
linkText: {
|
linkText: {
|
||||||
color: colors.red[500],
|
color: colors.red[500],
|
||||||
weight: fontWeights.normal,
|
weight: fontWeights.normal,
|
||||||
// TODO: add italic
|
italic: true
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,9 @@ import { withOpacity } from "../utils/color";
|
||||||
|
|
||||||
export interface SyntaxHighlightStyle {
|
export interface SyntaxHighlightStyle {
|
||||||
color: ColorToken;
|
color: ColorToken;
|
||||||
weight: FontWeightToken;
|
weight?: FontWeightToken;
|
||||||
|
underline?: boolean,
|
||||||
|
italic?: boolean,
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface Player {
|
export interface Player {
|
||||||
|
@ -49,12 +51,12 @@ export interface Syntax {
|
||||||
number: SyntaxHighlightStyle;
|
number: SyntaxHighlightStyle;
|
||||||
boolean: SyntaxHighlightStyle;
|
boolean: SyntaxHighlightStyle;
|
||||||
predictive: SyntaxHighlightStyle;
|
predictive: SyntaxHighlightStyle;
|
||||||
// TODO: Either move the following or rename
|
|
||||||
title: SyntaxHighlightStyle;
|
title: SyntaxHighlightStyle;
|
||||||
emphasis: SyntaxHighlightStyle;
|
emphasis: SyntaxHighlightStyle;
|
||||||
emphasisStrong: SyntaxHighlightStyle;
|
linkUri: SyntaxHighlightStyle;
|
||||||
linkUrl: SyntaxHighlightStyle;
|
|
||||||
linkText: SyntaxHighlightStyle;
|
linkText: SyntaxHighlightStyle;
|
||||||
|
|
||||||
|
[key: string]: SyntaxHighlightStyle;
|
||||||
};
|
};
|
||||||
|
|
||||||
export default interface Theme {
|
export default interface Theme {
|
||||||
|
|
|
@ -17,7 +17,7 @@ type SnakeCased<Type> = {
|
||||||
export default function snakeCaseTree<T>(object: T): SnakeCased<T> {
|
export default function snakeCaseTree<T>(object: T): SnakeCased<T> {
|
||||||
const snakeObject: any = {};
|
const snakeObject: any = {};
|
||||||
for (const key in object) {
|
for (const key in object) {
|
||||||
snakeObject[snakeCase(key)] = snakeCaseValue(object[key]);
|
snakeObject[snakeCase(key, { keepSpecialCharacters: true })] = snakeCaseValue(object[key]);
|
||||||
}
|
}
|
||||||
return snakeObject;
|
return snakeObject;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue