3e0c9b43a2
* change simulator svg
* change radio image
* Remove google fonts cdn
* change color of 'advanced' button
* font fix
* font fix 2
* display fix
* change fullsceen simulator bg
* Continuous servo
* handle continuous state
* adding shims
* update rendering for continuous servos
* fixing sim
* fix sig
* typo
* fix sim
* bump pxt
* bump pxt
* rerun travis
* Input blocks revision
- add Button and Pin event types
- merge onPinPressed & onPinReleased in new onPinEvent function
- create new onButtonEvent function
* update input blocks in docs and tests
* remove device_pin_release block
* Hide DAL.x behind Enum
* bring back deprecated blocks, but hide them
* shims and locales files
* fix input.input. typing
* remove buildpr
* bump V3
* update simulator aspect ratio
* add Loudness Block
* revoke loudness block
* Adds soundLevel
To be replaced by pxt-common-packages when DAL is updated.
* Remove P0 & P3 from AnalogPin
* Fix Sound and replace AnalogPin.P0
* remove approved extensions
* V4 Updates from remote Repo
* locales
* add storage functions
* fix storage functions
* fix int/float values
* decrease decimal precision
* reorder blocks
* Update BLE Settings and Storage Blocks
* Fetch MicroBit changes up to v4.0.18
* Update timing for LED Matrix usage
* use 32kb ram (mini v2)
* resize gatt table
* Revert "use 32kb ram (mini v2)"
This reverts commit 4b15592f0f
.
* fix missleading indentation
* add support for 32kb and 16kb ram
* only MIT extensions in preferredRepos
* remove extensions without MIT License file
* add updated extensions
* add extensions with MIT license
Co-authored-by: Juri <gitkraken@juriwolf.de>
Co-authored-by: Juri <info@juriwolf.de>
132 lines
3.7 KiB
TypeScript
132 lines
3.7 KiB
TypeScript
/// <reference no-default-lib="true"/>
|
|
|
|
enum ConsolePriority {
|
|
Debug = 0,
|
|
Log = 1,
|
|
Warning = 2,
|
|
Error = 3,
|
|
Silent = 4
|
|
}
|
|
|
|
/**
|
|
* Reading and writing data to the console output.
|
|
*/
|
|
//% weight=12 color=#002050 icon="\uf120"
|
|
//% advanced=true
|
|
namespace console {
|
|
type Listener = (priority: ConsolePriority, text: string) => void;
|
|
|
|
/**
|
|
* Minimum priority to send messages to listeners
|
|
*/
|
|
export let minPriority = ConsolePriority.Log;
|
|
|
|
let listeners: Listener[]
|
|
|
|
export function add(priority: ConsolePriority, message: any) {
|
|
if (priority < minPriority) return;
|
|
let text = inspect(message);
|
|
// add new line
|
|
text += "\n";
|
|
control.__log(priority, text)
|
|
// send to listeners
|
|
if (listeners)
|
|
for (let i = 0; i < listeners.length; ++i)
|
|
listeners[i](priority, text);
|
|
}
|
|
|
|
export function debug(text: any) {
|
|
add(ConsolePriority.Debug, text);
|
|
}
|
|
|
|
export function warn(text: any) {
|
|
add(ConsolePriority.Warning, text);
|
|
}
|
|
|
|
export function error(text: any) {
|
|
add(ConsolePriority.Error, text);
|
|
}
|
|
|
|
/**
|
|
* Write a line of text to the console output.
|
|
* @param value to send
|
|
*/
|
|
//% weight=90
|
|
//% help=console/log blockGap=8
|
|
export function log(value: any): void {
|
|
add(ConsolePriority.Log, value);
|
|
}
|
|
|
|
/**
|
|
* Write a name:value pair as a line of text to the console output.
|
|
* @param name name of the value stream, eg: "x"
|
|
* @param value to write
|
|
*/
|
|
//% weight=88 blockGap=8
|
|
//% help=console/log-value
|
|
export function logValue(name: any, value: any): void {
|
|
log(name ? `${inspect(name)}: ${inspect(value)}` : `${inspect(value)}`)
|
|
}
|
|
|
|
/**
|
|
* Convert any object or value to a string representation
|
|
* @param obj value to be converted to a string
|
|
* @param maxElements [optional] max number values in an object to include in output
|
|
*/
|
|
export function inspect(obj: any, maxElements = 20): string {
|
|
if (typeof obj == "string") {
|
|
return obj;
|
|
} else if (typeof obj == "number") {
|
|
return "" + obj;
|
|
} else if (Array.isArray(obj)) {
|
|
const asArr = (obj as Array<string>);
|
|
if (asArr.length <= maxElements) {
|
|
return asArr.join(",");
|
|
} else {
|
|
return `${asArr.slice(0, maxElements).join(",")}...`;
|
|
}
|
|
} else {
|
|
const asString = obj + "";
|
|
if (asString != "[object Object]"
|
|
&& asString != "[Object]") { // on arcade at least, default toString is [Object] on hardware instead of standard
|
|
return asString;
|
|
}
|
|
|
|
let keys = Object.keys(obj);
|
|
const snipped = keys.length > maxElements;
|
|
if (snipped) {
|
|
keys = keys.slice(0, maxElements);
|
|
}
|
|
|
|
return `{${keys.reduce(
|
|
(prev, currKey) => prev + `\n ${currKey}: ${obj[currKey]}`,
|
|
""
|
|
) + (snipped ? "\n ..." : "")
|
|
}
|
|
}`;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Adds a listener for the log messages
|
|
* @param listener
|
|
*/
|
|
//%
|
|
export function addListener(listener: (priority: ConsolePriority, text: string) => void) {
|
|
if (!listeners) listeners = []
|
|
if (!listener || listeners.indexOf(listener) > -1) return;
|
|
listeners.push(listener);
|
|
}
|
|
|
|
/**
|
|
* Removes a listener
|
|
* @param listener
|
|
*/
|
|
//%
|
|
export function removeListener(listener: (priority: ConsolePriority, text: string) => void) {
|
|
if (!listener || !listeners) return;
|
|
const i = listeners.indexOf(listener);
|
|
if (i > -1)
|
|
listeners.splice(i, 1);
|
|
}
|
|
} |