npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@tsonic/core

v10.0.46

Published

Core type definitions for Tsonic (versioned by .NET major)

Readme

@tsonic/core

Core language-facing declarations and intrinsics for Tsonic.

@tsonic/core is not an ambient surface by itself. It provides the shared modules that source packages and CLR binding packages use for primitive intent, language intrinsics, and compiler-recognized runtime helpers.

Install

npm install @tsonic/core

Modules

@tsonic/core/types.js

CLR primitive intent aliases:

import type { int, long, double, bool, char } from "@tsonic/core/types.js";

const age: int = 42 as int;
const total: long = 123 as long;
const ratio: double = 0.5;
const isActive: bool = true;
const initial: char = "T" as char;

@tsonic/core/lang.js

Compiler-recognized language intrinsics:

import { asinterface, defaultof, nameof, out, sizeof, stackalloc } from "@tsonic/core/lang.js";
import type { int } from "@tsonic/core/types.js";

const zero = defaultof<int>();
const name = nameof("customerId");
const bytes = stackalloc<int>(16);
void asinterface;
void out;
void sizeof;
void zero;
void name;
void bytes;

@tsonic/core/runtime.js

Runtime-facing helpers used by generated code and first-party source packages. This module includes compiler-recognized runtime declarations such as Union, DynamicObject, DictionaryAdapter, Structural, and JSON.

Broad values

Use concrete domain types at API boundaries whenever possible. When an API needs a deliberately broad value, use TypeScript unknown and narrow it before member access.

JsValue exists in @tsonic/core/types.js for first-party runtime declaration surfaces that model JavaScript carriers. It is not the general-purpose CLR object type. Generated CLR binding packages use unknown for System.Object and NonNullable<unknown> for value-type constraints.

Primitive aliases

Signed Integer Types

  • sbyte - System.SByte (-128 to 127)
  • short - System.Int16 (-32,768 to 32,767)
  • int - System.Int32 (-2,147,483,648 to 2,147,483,647)
  • long - System.Int64
  • nint - System.IntPtr (native int)
  • int128 - System.Int128

Unsigned Integer Types

  • byte - System.Byte (0 to 255)
  • ushort - System.UInt16 (0 to 65,535)
  • uint - System.UInt32 (0 to 4,294,967,295)
  • ulong - System.UInt64
  • nuint - System.UIntPtr (native uint)
  • uint128 - System.UInt128

Floating-Point Types

  • half - System.Half (16-bit float)
  • float - System.Single (32-bit float)
  • double - System.Double (64-bit float)
  • decimal - System.Decimal (128-bit decimal)

Other Types

  • bool - System.Boolean
  • char - System.Char (single UTF-16 code unit)
  • ptr<T> - C# unsafe pointer types

TypeScript versus Tsonic

The TypeScript checker sees most numeric aliases as number. Tsonic carries the semantic primitive identity through its own compiler pipeline and enforces the CLR-facing rules during compilation.

Use these aliases to express intent at source level; do not expect plain TypeScript to enforce every CLR primitive distinction by itself.

Versioning

This repo is versioned by .NET major:

  • .NET 10 declarations live under versions/10/.
  • The npm package is published as @tsonic/[email protected].

Development

npm install
npm run generate:10

License

MIT