diff --git a/src/vs/editor/standalone/browser/standaloneThemeServiceImpl.ts b/src/vs/editor/standalone/browser/standaloneThemeServiceImpl.ts index 9e3f3ac0c9c39..2aa6a9db44188 100644 --- a/src/vs/editor/standalone/browser/standaloneThemeServiceImpl.ts +++ b/src/vs/editor/standalone/browser/standaloneThemeServiceImpl.ts @@ -6,7 +6,7 @@ import * as dom from 'vs/base/browser/dom'; import { Color } from 'vs/base/common/color'; import { Emitter } from 'vs/base/common/event'; -import { TokenizationRegistry } from 'vs/editor/common/modes'; +import { FontStyle, TokenizationRegistry, TokenMetadata } from 'vs/editor/common/modes'; import { ITokenThemeRule, TokenTheme, generateTokensCSSForColorMap } from 'vs/editor/common/modes/supports/tokenization'; import { BuiltinTheme, IStandaloneTheme, IStandaloneThemeData, IStandaloneThemeService } from 'vs/editor/standalone/common/standaloneThemeService'; import { hc_black, vs, vs_dark } from 'vs/editor/standalone/common/themes'; @@ -136,7 +136,17 @@ class StandaloneTheme implements IStandaloneTheme { } public getTokenStyleMetadata(type: string, modifiers: string[], modelLanguage: string): ITokenStyle | undefined { - return undefined; + // use theme rules match + const style = this.tokenTheme._match([type].concat(modifiers).join('.')); + const metadata = style.metadata; + const foreground = TokenMetadata.getForeground(metadata); + const fontStyle = TokenMetadata.getFontStyle(metadata); + return { + foreground: foreground, + italic: Boolean(fontStyle & FontStyle.Italic), + bold: Boolean(fontStyle & FontStyle.Bold), + underline: Boolean(fontStyle & FontStyle.Underline) + }; } public get tokenColorMap(): string[] {