@foxglove/schemas 1.3.0 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. package/.github/workflows/ci.yml +6 -0
  2. package/README.md +6 -5
  3. package/internal/__snapshots__/exportTypescriptSchemata.test.ts.snap +1042 -0
  4. package/internal/exportTypescriptSchemata.d.ts +7 -0
  5. package/internal/exportTypescriptSchemata.d.ts.map +1 -0
  6. package/internal/exportTypescriptSchemata.js +33 -0
  7. package/internal/exportTypescriptSchemata.js.map +1 -0
  8. package/internal/exportTypescriptSchemata.test.d.ts +2 -0
  9. package/internal/exportTypescriptSchemata.test.d.ts.map +1 -0
  10. package/internal/exportTypescriptSchemata.test.js +10 -0
  11. package/internal/exportTypescriptSchemata.test.js.map +1 -0
  12. package/internal/exportTypescriptSchemata.test.ts +8 -0
  13. package/internal/exportTypescriptSchemata.ts +34 -0
  14. package/internal/generateRos.d.ts +3 -1
  15. package/internal/generateRos.d.ts.map +1 -1
  16. package/internal/generateRos.js +25 -11
  17. package/internal/generateRos.js.map +1 -1
  18. package/internal/generateRos.test.js +8 -8
  19. package/internal/generateRos.test.js.map +1 -1
  20. package/internal/generateRos.test.ts +8 -6
  21. package/internal/generateRos.ts +34 -17
  22. package/internal/index.d.ts +4 -3
  23. package/internal/index.d.ts.map +1 -1
  24. package/internal/index.js +4 -3
  25. package/internal/index.js.map +1 -1
  26. package/internal/index.ts +4 -3
  27. package/internal/schemas.d.ts.map +1 -1
  28. package/internal/schemas.js +17 -0
  29. package/internal/schemas.js.map +1 -1
  30. package/internal/schemas.ts +18 -0
  31. package/package.json +1 -1
  32. package/python/foxglove-schemas-flatbuffer/setup.cfg +1 -1
  33. package/python/foxglove-schemas-protobuf/setup.cfg +2 -2
  34. package/schemas/README.md +26 -0
  35. package/schemas/flatbuffer/LocationFix.fbs +8 -0
  36. package/schemas/jsonschema/LocationFix.json +20 -0
  37. package/schemas/jsonschema/index.d.ts +20 -0
  38. package/schemas/jsonschema/index.d.ts.map +1 -1
  39. package/schemas/jsonschema/index.js +20 -0
  40. package/schemas/jsonschema/index.js.map +1 -1
  41. package/schemas/jsonschema/index.ts +20 -0
  42. package/schemas/proto/foxglove/LocationFix.proto +8 -0
  43. package/schemas/ros1/LocationFix.msg +6 -0
  44. package/schemas/ros2/LocationFix.msg +6 -0
  45. package/schemas/typescript/LocationFix.d.ts +5 -0
  46. package/schemas/typescript/LocationFix.d.ts.map +1 -1
  47. package/schemas/typescript/LocationFix.ts +7 -0
  48. package/scripts/updateGeneratedFiles.js +10 -19
  49. package/scripts/updateGeneratedFiles.js.map +1 -1
  50. package/scripts/updateGeneratedFiles.ts +11 -26
@@ -4,16 +4,16 @@ import path from "path";
4
4
  import rimraf from "rimraf";
5
5
 
6
6
  import { generateRosMsg, generateRosMsgDefinition } from "../internal";
7
+ import { exportTypescriptSchemata } from "../internal/exportTypescriptSchemata";
7
8
  import {
8
9
  BYTE_VECTOR_FB,
9
10
  DURATION_FB,
10
- generateFlatbuffers,
11
11
  TIME_FB,
12
+ generateFlatbuffers,
12
13
  } from "../internal/generateFlatbufferSchema";
13
14
  import { generateJsonSchema } from "../internal/generateJsonSchema";
14
15
  import { generateMarkdown } from "../internal/generateMarkdown";
15
16
  import { generateProto } from "../internal/generateProto";
16
- import { generateTypeScript, DURATION_TS, TIME_TS } from "../internal/generateTypeScript";
17
17
  import { foxgloveEnumSchemas, foxgloveMessageSchemas } from "../internal/schemas";
18
18
 
19
19
  async function logProgress(message: string, body: () => Promise<void>) {
@@ -45,7 +45,9 @@ async function main({ outDir, rosOutDir }: { outDir: string; rosOutDir: string }
45
45
  if (schema.rosEquivalent != undefined) {
46
46
  continue;
47
47
  }
48
- const msg = generateRosMsg(generateRosMsgDefinition(schema, { rosVersion: 1 }));
48
+ const msg = generateRosMsg(generateRosMsgDefinition(schema, { rosVersion: 1 }), {
49
+ rosVersion: 1,
50
+ });
49
51
  await fs.writeFile(path.join(outDir, "ros1", `${schema.name}.msg`), msg);
50
52
  await fs.writeFile(path.join(rosOutDir, "ros1", `${schema.name}.msg`), msg);
51
53
  }
@@ -58,7 +60,9 @@ async function main({ outDir, rosOutDir }: { outDir: string; rosOutDir: string }
58
60
  if (schema.rosEquivalent != undefined) {
59
61
  continue;
60
62
  }
61
- const msg = generateRosMsg(generateRosMsgDefinition(schema, { rosVersion: 2 }));
63
+ const msg = generateRosMsg(generateRosMsgDefinition(schema, { rosVersion: 2 }), {
64
+ rosVersion: 2,
65
+ });
62
66
  await fs.writeFile(path.join(outDir, "ros2", `${schema.name}.msg`), msg);
63
67
  await fs.writeFile(path.join(rosOutDir, "ros2", `${schema.name}.msg`), msg);
64
68
  }
@@ -97,29 +101,10 @@ async function main({ outDir, rosOutDir }: { outDir: string; rosOutDir: string }
97
101
 
98
102
  await logProgress("Generating TypeScript definitions", async () => {
99
103
  await fs.mkdir(path.join(outDir, "typescript"), { recursive: true });
100
- await fs.writeFile(path.join(outDir, "typescript", "Time.ts"), TIME_TS);
101
- await fs.writeFile(path.join(outDir, "typescript", "Duration.ts"), DURATION_TS);
102
- for (const schema of Object.values(foxgloveMessageSchemas)) {
103
- await fs.writeFile(
104
- path.join(outDir, "typescript", `${schema.name}.ts`),
105
- generateTypeScript(schema),
106
- );
107
- }
108
- for (const schema of Object.values(foxgloveEnumSchemas)) {
109
- await fs.writeFile(
110
- path.join(outDir, "typescript", `${schema.name}.ts`),
111
- generateTypeScript(schema),
112
- );
113
- }
114
- const allSchemaNames = [
115
- ...Object.values(foxgloveMessageSchemas),
116
- ...Object.values(foxgloveEnumSchemas),
117
- ].sort((a, b) => a.name.localeCompare(b.name));
118
- let indexTS = "";
119
- for (const schema of allSchemaNames) {
120
- indexTS += `export * from "./${schema.name}";\n`;
104
+ const schemas = exportTypescriptSchemata();
105
+ for (const [name, source] of Object.entries(schemas)) {
106
+ await fs.writeFile(path.join(outDir, "typescript", `${name}.ts`), source);
121
107
  }
122
- await fs.writeFile(path.join(outDir, "typescript", `index.ts`), indexTS);
123
108
  });
124
109
 
125
110
  await logProgress("Generating README.md", async () => {