-
Notifications
You must be signed in to change notification settings - Fork 1.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Better handling loading terminal fonts #6913
Conversation
Signed-off-by: Roman <ixrock@gmail.com>
src/renderer/components/dock/terminal/terminal-fonts.injectable.ts
Outdated
Show resolved
Hide resolved
28059c3
to
cb140c9
Compare
Signed-off-by: Roman <ixrock@gmail.com>
cb140c9
to
e3961ad
Compare
Signed-off-by: Roman <ixrock@gmail.com>
6232894
to
4a271d5
Compare
"Source Code Pro", "Space Mono", "Ubuntu Mono", | ||
].map(customFont => { | ||
({ userStore, logger, terminalFonts }: Dependencies) => { | ||
const bundledFonts: SelectOption<string>[] = Array.from(terminalFonts.keys()).map(font => { | ||
const { fontFamily, fontSize } = userStore.terminalConfig; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: this line could be moved to outside the .map(() => {...})
which could simplify the code
@@ -9,7 +9,8 @@ import type { TabId } from "../dock/store"; | |||
import type { TerminalApi } from "../../../api/terminal-api"; | |||
import terminalSpawningPoolInjectable from "./terminal-spawning-pool.injectable"; | |||
import terminalConfigInjectable from "../../../../common/user-store/terminal-config.injectable"; | |||
import terminalCopyOnSelectInjectable from "../../../../common/user-store/terminal-copy-on-select.injectable"; | |||
import terminalCopyOnSelectInjectable |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this file probably doesn't need to be changed in this PR
|
||
export default getGlobalOverride(preloadAllTerminalFontsInjectable, () => { | ||
return { | ||
id: "", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: might be a good idea to keep the same id
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I intentionally didn't put any id to avoid duplication and keeping in sync with the injectable in future (it feels like it should not be responsible for this, maybe we should not ask id
at all and use it from passed injectable automatically) cc @jansav
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This ID is different from the Injectable ID because it is part of the data which is created, same as any other field (could have been call name
).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why it's different? If I duplicate the string it would be the same. Moreover, we can use different ID from returned object (from runnable):
export const preloadAllTerminalFontsInjectable = getInjectable({
id: "preloadAllTerminalFontsInjectable",
instantiate(di) {
const terminalFonts = di.inject(terminalFontsInjectable);
const preloadFont = di.inject(preloadTerminalFontInjectable);
return {
id: "preload-all-terminal-fonts", // <--- THAT ONE
async run() {
await Promise.allSettled(
Array.from(terminalFonts.keys()).map(preloadFont),
);
},
};
},
injectionToken: beforeFrameStartsFirstInjectionToken,
causesSideEffects: true,
});
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
id: "preload-all-terminal-fonts", // <--- THAT ONE
This is the one that I am talking about
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, I mean this ID should be utilized automatically from passed injectable to make id
optional.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fair enough that would be nicer indeed
id: "terminalFontsInjectable", | ||
|
||
instantiate() { | ||
return new Map([ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: either this map should be created from a call to di.injectMany(terminalFontInjectionToken)
(for some new injection token) and then be fully OCP or it doesn't need to be wrapped in an injectable.
|
||
injectionToken: beforeFrameStartsFirstInjectionToken, | ||
|
||
causesSideEffects: true, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
actually on further note, given that preloadTerminalFont
is causesSideEffects: true
this one doesn't have to be since it doesn't introduce any new side effects.
Merging, the above comments can be resolved in a future PR |
Moving out from loading fonts only by CSS to JS with FontFace.load() interface due rendering terminal on canvas and since it's more reliable/controllable way of loading font files in general).
Screen.Recording.2023-01-11.at.20.04.17.mov
close #5019