Files
flatbuffers/tests/ts/union_vector/character.js
Björn Harrtell ef76b5ece4 [TS/JS] Entry point per namespace and reworked 1.x compatible single file build (#7510)
* [TS/JS] Entry point per namespace

* Fix handling of outputpath and array_test

* Attempt to fix generate_code

* Fix cwd for ts in generate_code

* Attempt to fixup bazel and some docs

* Add --ts-flat-files to bazel build to get bundle

* Move to DEFAULT_FLATC_TS_ARGS

* Attempt to add esbuild

* Attempt to use npm instead

* Remove futile attempt to add esbuild

* Attempt to as bazel esbuild

* Shuffle

* Upgrade bazel deps

* Revert failed attempts to get bazel working

* Ignore flatc tests for now

* Add esbuild dependency

* `package.json` Include esbuild

* `WORKSPACE` Add fetching esbuild binary

* Update WORKSPACE

* Unfreeze Lockfile

* Update WORKSPACE

* Update BUILD.bazel

* Rework to suggest instead of running external bundler

* Add esbuild generation to test script

* Prelim bundle test

* Run test JavaScriptTest from flatbuffers 1.x

* Deps upgrade

* Clang format fix

* Revert bazel changes

* Fix newline

* Generate with type declarations

* Handle "empty" root namespace

* Adjust tests for typescript_keywords.ts

* Separate test procedure for old node resolution module output

* Fix rel path for root level re-exports

* Bazel support for esbuild-based flatc

Unfortunately, we lose typing information because the new esbuild method
of generating single files does not generate type information.

The method used here is a bit hack-ish because it relies on parsing the
console output of flatc to figure out what to do.

* Try to fix bazel build for when node isn't present on host

* Auto formatting fixes

* Fix missing generated code

Co-authored-by: Derek Bailey <derekbailey@google.com>
Co-authored-by: James Kuszmaul <jabukuszmaul+collab@gmail.com>
2023-01-21 12:22:22 -08:00

39 lines
1.6 KiB
JavaScript

// automatically generated by the FlatBuffers compiler, do not modify
import { Attacker } from './attacker.js';
import { BookReader } from './book-reader.js';
import { Rapunzel } from './rapunzel.js';
export var Character;
(function (Character) {
Character[Character["NONE"] = 0] = "NONE";
Character[Character["MuLan"] = 1] = "MuLan";
Character[Character["Rapunzel"] = 2] = "Rapunzel";
Character[Character["Belle"] = 3] = "Belle";
Character[Character["BookFan"] = 4] = "BookFan";
Character[Character["Other"] = 5] = "Other";
Character[Character["Unused"] = 6] = "Unused";
})(Character = Character || (Character = {}));
export function unionToCharacter(type, accessor) {
switch (Character[type]) {
case 'NONE': return null;
case 'MuLan': return accessor(new Attacker());
case 'Rapunzel': return accessor(new Rapunzel());
case 'Belle': return accessor(new BookReader());
case 'BookFan': return accessor(new BookReader());
case 'Other': return accessor('');
case 'Unused': return accessor('');
default: return null;
}
}
export function unionListToCharacter(type, accessor, index) {
switch (Character[type]) {
case 'NONE': return null;
case 'MuLan': return accessor(index, new Attacker());
case 'Rapunzel': return accessor(index, new Rapunzel());
case 'Belle': return accessor(index, new BookReader());
case 'BookFan': return accessor(index, new BookReader());
case 'Other': return accessor(index, '');
case 'Unused': return accessor(index, '');
default: return null;
}
}