本文整理匯總了TypeScript中@src/lib/logging.Logger類的典型用法代碼示例。如果您正苦於以下問題:TypeScript Logger類的具體用法?TypeScript Logger怎麽用?TypeScript Logger使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了Logger類的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: parser
export function parser(exstr: string, all_excmds: any): any[] {
// Expand aliases
const expandedExstr = aliases.expandExstr(exstr)
const [func, ...args] = expandedExstr.trim().split(/\s+/)
// Try to find which namespace (ex, text, ...) the command is in
const dotIndex = func.indexOf(".")
const namespce = func.substring(0, dotIndex)
const funcName = func.substring(dotIndex + 1)
const excmds = all_excmds[namespce]
if (excmds === undefined) {
throw new Error(`Unknwown namespace: ${namespce}.`);
}
// Convert arguments, but only for ex commands
let converted_args
if (namespce == "") {
let types
try {
types = (metadata
.getFile("src/excmds.ts")
.getFunction(funcName)
.type as FunctionType)
.args
} catch (e) {
throw `Could not find type information for excmd ${funcName}`
}
try {
converted_args = convertArgs(types, args)
} catch (e) {
logger.error("Error executing or parsing:", exstr, e)
throw e
}
} else {
converted_args = args
}
if (excmds[funcName] === undefined) {
logger.error("Not an excmd:", exstr)
throw `Not an excmd: ${func}`
}
return [excmds[funcName], converted_args]
}
示例2: updateVersion
async function updateVersion() {
try {
// If any monster any makes a novelty tag this will break.
// So let's just ignore any errors.
const parser = new RssParser()
const feed = await parser.parseURL("https://github.com/tridactyl/tridactyl/tags.atom")
const mostRecent = feed.items[0]
// Update our last update check timestamp and the version itself.
Config.set("update", "lastchecktime", Date.now())
highestKnownVersion = {
version: mostRecent.title,
releaseDate: new Date(mostRecent.pubDate), // e.g. 2018-12-04T15:24:43.000Z
}
logger.debug("Checked for new version of Tridactyl, found ", highestKnownVersion)
} catch (e) {
logger.error("Error while checking for updates: ", e)
}
}
示例3: Error
export async function create(
name: string,
color = "random",
icon = "fingerprint",
): Promise<string> {
if (color === "random") color = chooseRandomColor()
const container = fromString(name, color, icon)
// browser.contextualIdentities.create does not accept a cookieStoreId property.
delete container.cookieStoreId
logger.debug(container)
if (await exists(name)) {
logger.debug(`[Container.create] container already exists ${container}`)
throw new Error(
`[Container.create] container already exists, aborting.`,
)
} else {
const res = await browser.contextualIdentities.create(container)
return res.cookieStoreId
}
}
示例4: addContentStateChangedListener
addContentStateChangedListener((property, oldMode, oldValue, newValue) => {
let mode = newValue
let suffix = ""
let result = ""
if (property !== "mode") {
if (property === "suffix") {
mode = oldMode
suffix = newValue
} else {
return
}
}
const privateMode = browser.extension.inIncognitoContext
? "TridactylPrivate"
: ""
statusIndicator.className =
"cleanslate TridactylStatusIndicator " + privateMode
if (
dom.isTextEditable(document.activeElement) &&
!["input", "ignore"].includes(mode)
) {
statusIndicator.textContent = "insert"
// this doesn't work; statusIndicator.style is full of empty string
// statusIndicator.style.borderColor = "green !important"
// need to fix loss of focus by click: doesn't do anything here.
} else if (
mode === "insert" &&
!dom.isTextEditable(document.activeElement)
) {
statusIndicator.textContent = "normal"
// statusIndicator.style.borderColor = "lightgray !important"
} else {
result = mode
}
const modeindicatorshowkeys = Config.get("modeindicatorshowkeys")
if (modeindicatorshowkeys === "true" && suffix !== "") {
result = mode + " " + suffix
}
logger.debug(
"statusindicator: ",
result,
";",
"config",
modeindicatorshowkeys,
)
statusIndicator.textContent = result
statusIndicator.className +=
" TridactylMode" + statusIndicator.textContent
if (config.get("modeindicator") !== "true") statusIndicator.remove()
})
示例5: registerEvListenerAction
export function registerEvListenerAction(
elem: EventTarget,
add: boolean,
event: string,
) {
// We're only interested in the subset of EventTargets that are Elements.
if (!(elem instanceof Element)) {
return
}
// Prevent bad elements from being processed
//
// This is defence in depth: we should never receive an invalid elem here
// because add/removeEventListener currently throws a TypeError if the given
// element is not a standard library EventTarget subclass.
try {
// Node prototype functions work on the C++ representation of the
// Node, which a faked JS object won't have.
// hasChildNodes() is chosen because it should be cheap.
Node.prototype.hasChildNodes.apply(elem)
} catch (e) {
// Don't throw a real exception because addEventListener wouldn't and we
// don't want to break content code.
logger.error("Elem is not a real Node", elem)
return
}
switch (event) {
case "click":
case "mousedown":
case "mouseup":
case "mouseover":
if (add) {
hintworthy_js_elems.push(elem)
} else {
// Possible bug: If a page adds an event listener for "click" and
// "mousedown" and removes "mousedown" twice, we lose track of the
// elem even though it still has a "click" listener.
// Fixing this might not be worth the added complexity.
const index = hintworthy_js_elems.indexOf(elem)
if (index >= 0) hintworthy_js_elems.splice(index, 1)
}
}
}
示例6: exists
export async function exists(cname: string): Promise<boolean> {
let exists = false
try {
const containers = await getAll()
const res = containers.filter(c => {
return c.name.toLowerCase() === cname.toLowerCase()
})
if (res.length > 0) {
exists = true
}
} catch (e) {
exists = true // Make sure we don't accidentally break the constraint on query error.
logger.error(
"[Container.exists] Error querying contextualIdentities:",
e,
)
}
return exists
}
示例7: theme
export async function theme(element) {
// Remove any old theme
for (const theme of THEMES.map(prefixTheme)) {
element.classList.remove(theme)
}
if (insertedCSS) {
// Typescript doesn't seem to be aware than remove/insertCSS's tabid
// argument is optional
await browserBg.tabs.removeCSS(await ownTabId(), customCss)
insertedCSS = false
}
const newTheme = await config.getAsync("theme")
// Add a class corresponding to config.get('theme')
if (newTheme !== "default") {
element.classList.add(prefixTheme(newTheme))
}
// Insert custom css if needed
if (newTheme !== "default" && !THEMES.includes(newTheme)) {
customCss.code = await config.getAsync("customthemes", newTheme)
if (customCss.code) {
await browserBg.tabs.insertCSS(await ownTabId(), customCss)
insertedCSS = true
} else {
logger.error("Theme " + newTheme + " couldn't be found.")
}
}
// Record for re-theming
// considering only elements :root (page and cmdline_iframe)
// TODO:
// - Find ways to check if element is already pushed
if (
THEMED_ELEMENTS.length < 2 &&
element.tagName.toUpperCase() === "HTML"
) {
THEMED_ELEMENTS.push(element)
}
}