Files
Alexander Vakrilov cc97a16800 feat: Scoped Packages (#7911)
* chore: move tns-core-modules to nativescript-core

* chore: preparing compat generate script

* chore: add missing definitions

* chore: no need for http-request to be private

* chore: packages chore

* test: generate tests for tns-core-modules

* chore: add anroid module for consistency

* chore: add .npmignore

* chore: added privateModulesWhitelist

* chore(webpack): added bundle-entry-points

* chore: scripts

* chore: tests changed to use @ns/core

* test: add scoped-packages test project

* test: fix types

* test: update test project

* chore: build scripts

* chore: update build script

* chore: npm scripts cleanup

* chore: make the compat pgk work with old wp config

* test: generate diff friendly tests

* chore: create barrel exports

* chore: move files after rebase

* chore: typedoc config

* chore: compat mode

* chore: review of barrels

* chore: remove tns-core-modules import after rebase

* chore: dev workflow setup

* chore: update developer-workflow

* docs: experiment with API extractor

* chore: api-extractor and barrel exports

* chore: api-extractor configs

* chore: generate d.ts rollup with api-extractor

* refactor: move methods inside Frame

* chore: fic tests to use Frame static methods

* refactor: create Builder class

* refactor: use Builder class in tests

* refactor: include Style in ui barrel

* chore: separate compat build script

* chore: fix tslint errors

* chore: update NATIVESCRIPT_CORE_ARGS

* chore: fix compat pack

* chore: fix ui-test-app build with linked modules

* chore: Application, ApplicationSettings, Connectivity and Http

* chore: export Trace, Profiling and Utils

* refactor: Static create methods for ImageSource

* chore: fix deprecated usages of ImageSource

* chore: move Span and FormattedString to ui

* chore: add events-args and ImageSource to index files

* chore: check for CLI >= 6.2 when building for IOS

* chore: update travis build

* chore: copy Pod file to compat package

* chore: update error msg ui-tests-app

* refactor: Apply suggestions from code review

Co-Authored-By: Martin Yankov <m.i.yankov@gmail.com>

* chore: typings and refs

* chore: add missing d.ts files for public API

* chore: adress code review FB

* chore: update api-report

* chore: dev-workflow for other apps

* chore: api update

* chore: update api-report
2019-10-17 00:45:33 +03:00

162 lines
5.4 KiB
TypeScript

/**
* Contains contains utility methods for profiling.
* All methods in this module are experimental and may be changed in a non-major version.
* @module "profiling"
*/ /** */
interface TimerInfo {
totalTime: number;
count: number;
}
/**
* Profiling mode to use.
* - `counters` Accumulates method call counts and times until dumpProfiles is called and then prints aggregated statistic in the console. This is the default.
* - `timeline` Outputs method names along start/end timestamps in the console on the go.
* - `lifecycle` Outputs basic non-verbose times for startup, navigation, etc.
*/
type InstrumentationMode = "counters" | "timeline" | "lifecycle";
/**
* Logging levels in order of verbosity.
*/
export enum Level {
none,
lifecycle,
timeline,
}
/**
* Get the current logging level.
*/
export function level(): Level;
/**
* Enables profiling.
*
* Upon loading of the module it will cache the package.json of the app and check if there is a "profiling" key set,
* its value can be one of the options available for InstrumentationMode, and if set,
* enable() will be called in pre app start with the value in the package.json.
*
* An example for an `app/package.json` enabling the manual instrumentation profiling is:
* ```
* {
* "main": "main.js",
* "profiling": "timeline"
* }
* ```
*
* @param type Profiling mode to use.
* - "counters" - Accumulates method call counts and times until dumpProfiles is called and then prints aggregated statistic in the console. This is the default.
* - "timeline" - Outputs method names along start/end timestamps in the console on the go.
* - "lifecycle" - Outputs basic non-verbose times for startup, navigation, etc.
*/
export declare function enable(type?: InstrumentationMode): void;
/**
* Disables profiling.
*/
export declare function disable(): void;
/**
* Gets accurate system timestamp in ms.
*/
export declare function time(): number;
/**
* Starts a timer with a specific name.
* Works only if profiling is enabled.
* @param name Name of the timer.
*/
export declare function start(name: string): void;
/**
* Pauses a timer with a specific name. This will increase call count and accumulate time.
* Works only if profiling is enabled.
* @param name Name of the timer.
* @returns TimerInfo for the paused timer.
*/
export declare function stop(name: string): TimerInfo;
/**
* Read a timer info.
* @param name The name of the timer to obtain information about.
*/
export function timer(name: string): TimerInfo;
/**
* Returns true if a timer is currently running.
* @param name Name of the timer.
* @returns true is the timer is currently running.
*/
export declare function isRunning(name: string): boolean;
/**
* Method decorator factory. It will intercept the method call and start and pause a timer before and after the method call.
* Works only if profiling is enabled.
* @param name Name of the timer which will be used for method calls. If not provided - the name of the method will be used.
*/
export declare function profile(name?: string): MethodDecorator;
/**
* Function factory. It will intercept the function call and start and pause a timer before and after the function call. Works only if profiling is enabled.
* Works only if profiling is enabled.
* @param fn The function to wrap. Uses the function name to track the times.
*/
export declare function profile<F extends Function>(fn: F): F;
/**
* Function factory. It will intercept the function call and start and pause a timer before and after the function call. Works only if profiling is enabled.
* @param name The name used to track calls and times.
* @param fn The function to wrap.
*/
export declare function profile<F extends Function>(name: string, fn: F): F;
/**
* Method decorator. It will intercept the method calls and start and pause a timer before and after the method call. Works only if profiling is enabled.
*/
export declare function profile<T>(target: Object, propertyKey: string | symbol, descriptor: TypedPropertyDescriptor<T>): TypedPropertyDescriptor<T> | void;
export function profile(): any;
/**
* Prints the timer for all methods instrumented with profile decorator.
*/
export declare function dumpProfiles(): void;
/**
* Resets the timers for all methods instrumented with profile decorator.
*/
export function resetProfiles(): void;
/**
* Starts android cpu profiling.
* @param name Name of the cpu profiling session.
*/
export declare function startCPUProfile(name: string): void;
/**
* Stops android cpu profiling.
* @param name Name of the cpu profiling session.
*/
export declare function stopCPUProfile(name: string): void;
/**
* Gets the uptime of the current process in milliseconds.
*/
export function uptime(): number;
/**
* Logs important messages. Contrary to console.log's behavior, the profiling log should output even for release builds.
*/
export function log(message: string): void;
/**
* Manually output profiling messages. The `@profile` decorator is useful when measuring times that function calls take on the stack
* but when measuring times between longer periods (startup times, times between the navigatingTo - navigatedTo events etc.)
* you can call this method and provide manually the times to be logged.
* @param message A string message
* @param start The start time (see `time()`)
* @param end The end time (see `time()`)
*/
export function trace(message: string, start: number, end: number): void;