@futpib/parser 1.0.2 → 1.0.4

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 (311) hide show
  1. package/.github/copilot-instructions.md +149 -0
  2. package/.github/workflows/copilot-setup-steps.yml +18 -0
  3. package/.github/workflows/main.yml +29 -8
  4. package/.yarn/releases/yarn-4.9.4.cjs +942 -0
  5. package/.yarnrc.yml +1 -1
  6. package/build/allSettledStream.js +1 -1
  7. package/build/allSettledStream.test.js +2 -2
  8. package/build/androidPackageParser.d.ts +1 -1
  9. package/build/androidPackageParser.js +5 -3
  10. package/build/androidPackageParser.test.js +7 -7
  11. package/build/androidPackageUnparser.d.ts +2 -2
  12. package/build/androidPackageUnparser.js +18 -14
  13. package/build/androidPackageUnparser.test.js +7 -7
  14. package/build/arbitrarilySlicedAsyncInterator.js +2 -1
  15. package/build/arbitraryDalvikBytecode.d.ts +4 -0
  16. package/build/arbitraryDalvikBytecode.js +640 -0
  17. package/build/arbitraryDalvikExecutable.d.ts +3 -0
  18. package/build/arbitraryDalvikExecutable.js +282 -0
  19. package/build/arbitraryDosDateTime.js +1 -0
  20. package/build/arbitraryZipStream.js +1 -1
  21. package/build/arrayParser.js +2 -2
  22. package/build/arrayUnparser.d.ts +1 -1
  23. package/build/backsmali.d.ts +3 -1
  24. package/build/backsmali.js +31 -3
  25. package/build/bash.d.ts +84 -0
  26. package/build/bash.js +1 -0
  27. package/build/bashParser.d.ts +6 -0
  28. package/build/bashParser.js +294 -0
  29. package/build/bashParser.test.d.ts +1 -0
  30. package/build/bashParser.test.js +181 -0
  31. package/build/customInvariant.d.ts +2 -1
  32. package/build/customInvariant.js +4 -6
  33. package/build/dalvikBytecodeParser/formatParsers.d.ts +76 -2
  34. package/build/dalvikBytecodeParser/formatParsers.js +146 -11
  35. package/build/dalvikBytecodeParser/formatSizes.d.ts +34 -0
  36. package/build/dalvikBytecodeParser/formatSizes.js +34 -0
  37. package/build/dalvikBytecodeParser/operationFormats.d.ts +225 -0
  38. package/build/dalvikBytecodeParser/operationFormats.js +225 -0
  39. package/build/dalvikBytecodeParser.d.ts +1105 -5
  40. package/build/dalvikBytecodeParser.js +658 -205
  41. package/build/dalvikBytecodeUnparser/formatUnparsers.d.ts +152 -0
  42. package/build/dalvikBytecodeUnparser/formatUnparsers.js +225 -0
  43. package/build/dalvikBytecodeUnparser.d.ts +3 -0
  44. package/build/dalvikBytecodeUnparser.js +642 -0
  45. package/build/dalvikBytecodeUnparser.test.d.ts +1 -0
  46. package/build/dalvikBytecodeUnparser.test.js +25 -0
  47. package/build/dalvikExecutable.d.ts +65 -8
  48. package/build/dalvikExecutable.js +36 -0
  49. package/build/dalvikExecutableParser/stringSyntaxParser.d.ts +1 -1
  50. package/build/dalvikExecutableParser/stringSyntaxParser.js +17 -17
  51. package/build/dalvikExecutableParser/typeParsers.d.ts +2 -1
  52. package/build/dalvikExecutableParser/typeParsers.js +16 -11
  53. package/build/dalvikExecutableParser/typedNumbers.d.ts +85 -69
  54. package/build/dalvikExecutableParser/typedNumbers.js +0 -1
  55. package/build/dalvikExecutableParser.d.ts +2 -2
  56. package/build/dalvikExecutableParser.js +655 -337
  57. package/build/dalvikExecutableParser.test.js +24 -22
  58. package/build/dalvikExecutableParserAgainstSmaliParser.test.js +223 -246
  59. package/build/dalvikExecutableUnparser/annotationUnparsers.d.ts +14 -0
  60. package/build/dalvikExecutableUnparser/annotationUnparsers.js +97 -0
  61. package/build/dalvikExecutableUnparser/poolBuilders.d.ts +49 -0
  62. package/build/dalvikExecutableUnparser/poolBuilders.js +140 -0
  63. package/build/dalvikExecutableUnparser/poolScanners.d.ts +4 -0
  64. package/build/dalvikExecutableUnparser/poolScanners.js +220 -0
  65. package/build/dalvikExecutableUnparser/sectionUnparsers.d.ts +25 -0
  66. package/build/dalvikExecutableUnparser/sectionUnparsers.js +581 -0
  67. package/build/dalvikExecutableUnparser/utils.d.ts +10 -0
  68. package/build/dalvikExecutableUnparser/utils.js +108 -0
  69. package/build/dalvikExecutableUnparser.d.ts +4 -0
  70. package/build/dalvikExecutableUnparser.js +406 -0
  71. package/build/dalvikExecutableUnparser.test.d.ts +1 -0
  72. package/build/dalvikExecutableUnparser.test.js +31 -0
  73. package/build/debugLogInputParser.js +1 -1
  74. package/build/disjunctionParser.d.ts +2 -2
  75. package/build/disjunctionParser.js +2 -2
  76. package/build/elementTerminatedArrayParser.d.ts +2 -2
  77. package/build/elementTerminatedArrayParser.js +1 -1
  78. package/build/elementTerminatedArrayParser.test.js +5 -5
  79. package/build/elementTerminatedSequenceArrayParser.d.ts +2 -2
  80. package/build/elementTerminatedSequenceArrayParser.js +1 -1
  81. package/build/elementTerminatedSequenceArrayParser.test.js +2 -2
  82. package/build/elementTerminatedSequenceParser.d.ts +2 -2
  83. package/build/elementTerminatedSequenceParser.js +1 -1
  84. package/build/elementTerminatedSequenceParser.test.js +2 -2
  85. package/build/endOfInputParser.d.ts +1 -1
  86. package/build/exactElementSwitchParser.d.ts +3 -0
  87. package/build/exactElementSwitchParser.js +22 -0
  88. package/build/fetchCid.js +2 -6
  89. package/build/fetchCid.test.d.ts +1 -0
  90. package/build/fetchCid.test.js +16 -0
  91. package/build/fixedLengthSequenceParser.test.js +2 -2
  92. package/build/hasExecutable.js +2 -2
  93. package/build/highResolutionTimer.js +1 -1
  94. package/build/index.d.ts +24 -2
  95. package/build/index.js +22 -1
  96. package/build/inputReader.d.ts +1 -1
  97. package/build/inputReader.test.js +33 -45
  98. package/build/javaKeyStoreParser.test.js +6 -6
  99. package/build/jsonParser.js +8 -8
  100. package/build/lazyMessageError.d.ts +48 -0
  101. package/build/lazyMessageError.js +53 -0
  102. package/build/lazyMessageError.test.d.ts +1 -0
  103. package/build/lazyMessageError.test.js +15 -0
  104. package/build/leb128Parser.d.ts +1 -1
  105. package/build/leb128Parser.js +10 -10
  106. package/build/leb128Parser.test.js +7 -7
  107. package/build/negativeLookaheadParser.js +2 -2
  108. package/build/negativeLookaheadParser.test.js +4 -4
  109. package/build/noStackCaptureOverheadError.d.ts +4 -0
  110. package/build/noStackCaptureOverheadError.js +9 -0
  111. package/build/noStackCaptureOverheadError.test.d.ts +1 -0
  112. package/build/noStackCaptureOverheadError.test.js +15 -0
  113. package/build/nonEmptyArrayParser.js +2 -2
  114. package/build/nonEmptyArrayParser.test.js +2 -1
  115. package/build/optionalParser.js +2 -2
  116. package/build/parser.d.ts +2 -1
  117. package/build/parser.js +23 -8
  118. package/build/parser.test.js +78 -29
  119. package/build/parserConsumedSequenceParser.d.ts +1 -1
  120. package/build/parserConsumedSequenceParser.js +2 -2
  121. package/build/parserContext.d.ts +8 -6
  122. package/build/parserContext.js +60 -33
  123. package/build/parserContext.test.js +7 -3
  124. package/build/parserError.d.ts +603 -44
  125. package/build/parserError.js +98 -53
  126. package/build/parserImplementationInvariant.d.ts +1 -1
  127. package/build/parserImplementationInvariant.js +2 -2
  128. package/build/parserInputCompanion.js +2 -2
  129. package/build/promiseCompose.js +1 -2
  130. package/build/regexpParser.d.ts +2 -0
  131. package/build/regexpParser.js +71 -0
  132. package/build/regexpParser.test.d.ts +1 -0
  133. package/build/regexpParser.test.js +83 -0
  134. package/build/regularExpression.d.ts +63 -0
  135. package/build/regularExpression.js +1 -0
  136. package/build/regularExpressionParser.d.ts +3 -0
  137. package/build/regularExpressionParser.js +580 -0
  138. package/build/regularExpressionParser.test.d.ts +1 -0
  139. package/build/regularExpressionParser.test.js +89 -0
  140. package/build/separatedArrayParser.js +2 -2
  141. package/build/separatedNonEmptyArrayParser.d.ts +2 -0
  142. package/build/separatedNonEmptyArrayParser.js +40 -0
  143. package/build/separatedNonEmptyArrayParser.test.d.ts +1 -0
  144. package/build/separatedNonEmptyArrayParser.test.js +66 -0
  145. package/build/sequenceBuffer.js +1 -1
  146. package/build/sequenceTerminatedSequenceParser.d.ts +2 -2
  147. package/build/sequenceTerminatedSequenceParser.js +3 -3
  148. package/build/sequenceTerminatedSequenceParser.test.js +1 -1
  149. package/build/sequenceUnparser.d.ts +1 -1
  150. package/build/skipToParser.d.ts +1 -1
  151. package/build/skipToParser.js +2 -2
  152. package/build/sliceBoundedParser.test.js +4 -9
  153. package/build/smali.d.ts +1 -1
  154. package/build/smali.js +6 -2
  155. package/build/smaliParser.d.ts +62 -6
  156. package/build/smaliParser.js +1721 -296
  157. package/build/smaliParser.test.js +338 -43
  158. package/build/stringFromAsyncIterable.d.ts +1 -0
  159. package/build/stringFromAsyncIterable.js +7 -0
  160. package/build/terminatedArrayParser.js +4 -4
  161. package/build/terminatedArrayParser.test.js +7 -7
  162. package/build/toAsyncIterator.js +4 -4
  163. package/build/unionParser.d.ts +1 -1
  164. package/build/unionParser.js +2 -2
  165. package/build/unionParser.test.js +3 -3
  166. package/build/unparser.d.ts +3 -3
  167. package/build/unparser.js +6 -4
  168. package/build/unparser.test.js +7 -19
  169. package/build/unparserContext.d.ts +2 -2
  170. package/build/unparserContext.js +2 -3
  171. package/build/unparserError.d.ts +2 -1
  172. package/build/unparserError.js +2 -1
  173. package/build/unparserImplementationInvariant.d.ts +1 -1
  174. package/build/unparserOutputCompanion.d.ts +1 -1
  175. package/build/unparserOutputCompanion.js +1 -1
  176. package/build/zipParser.js +1 -1
  177. package/build/zipUnparser.d.ts +3 -3
  178. package/build/zipUnparser.js +9 -19
  179. package/build/zipUnparser.test.js +1 -1
  180. package/package.json +20 -26
  181. package/src/allSettledStream.test.ts +2 -2
  182. package/src/allSettledStream.ts +3 -3
  183. package/src/androidPackageParser.test.ts +17 -19
  184. package/src/androidPackageParser.ts +129 -171
  185. package/src/androidPackageUnparser.test.ts +19 -21
  186. package/src/androidPackageUnparser.ts +23 -17
  187. package/src/arbitrarilySlicedAsyncInterable.ts +1 -1
  188. package/src/arbitrarilySlicedAsyncInterator.ts +4 -4
  189. package/src/arbitraryDalvikBytecode.ts +992 -0
  190. package/src/arbitraryDalvikExecutable.ts +434 -0
  191. package/src/arbitraryDosDateTime.ts +1 -0
  192. package/src/arbitraryZipStream.ts +1 -1
  193. package/src/arrayParser.ts +2 -2
  194. package/src/arrayUnparser.ts +2 -2
  195. package/src/backsmali.ts +48 -4
  196. package/src/bash.ts +120 -0
  197. package/src/bashParser.test.ts +332 -0
  198. package/src/bashParser.ts +461 -0
  199. package/src/bsonParser.test.ts +12 -14
  200. package/src/customInvariant.ts +8 -12
  201. package/src/dalvikBytecodeParser/formatParsers.ts +376 -17
  202. package/src/dalvikBytecodeParser/formatSizes.ts +35 -0
  203. package/src/dalvikBytecodeParser/operationFormats.ts +226 -0
  204. package/src/dalvikBytecodeParser.ts +1042 -243
  205. package/src/dalvikBytecodeUnparser/formatUnparsers.ts +442 -0
  206. package/src/dalvikBytecodeUnparser.test.ts +44 -0
  207. package/src/dalvikBytecodeUnparser.ts +758 -0
  208. package/src/dalvikExecutable.ts +110 -48
  209. package/src/dalvikExecutableParser/stringSyntaxParser.ts +33 -33
  210. package/src/dalvikExecutableParser/typeParsers.ts +23 -14
  211. package/src/dalvikExecutableParser/typedNumbers.ts +19 -19
  212. package/src/dalvikExecutableParser.test.ts +60 -60
  213. package/src/dalvikExecutableParser.test.ts.md +6 -6
  214. package/src/dalvikExecutableParser.test.ts.snap +0 -0
  215. package/src/dalvikExecutableParser.ts +911 -434
  216. package/src/dalvikExecutableParserAgainstSmaliParser.test.ts +256 -239
  217. package/src/dalvikExecutableUnparser/annotationUnparsers.ts +135 -0
  218. package/src/dalvikExecutableUnparser/poolBuilders.ts +189 -0
  219. package/src/dalvikExecutableUnparser/poolScanners.ts +297 -0
  220. package/src/dalvikExecutableUnparser/sectionUnparsers.ts +683 -0
  221. package/src/dalvikExecutableUnparser/utils.ts +149 -0
  222. package/src/dalvikExecutableUnparser.test.ts +57 -0
  223. package/src/dalvikExecutableUnparser.ts +581 -0
  224. package/src/debugLogInputParser.ts +1 -1
  225. package/src/disjunctionParser.ts +5 -5
  226. package/src/elementTerminatedArrayParser.test.ts +8 -8
  227. package/src/elementTerminatedArrayParser.ts +2 -2
  228. package/src/elementTerminatedSequenceArrayParser.test.ts +4 -6
  229. package/src/elementTerminatedSequenceArrayParser.ts +2 -2
  230. package/src/elementTerminatedSequenceParser.test.ts +4 -6
  231. package/src/elementTerminatedSequenceParser.ts +2 -2
  232. package/src/endOfInputParser.ts +1 -1
  233. package/src/exactElementSwitchParser.ts +41 -0
  234. package/src/fetchCid.test.ts +20 -0
  235. package/src/fetchCid.ts +3 -7
  236. package/src/fixedLengthSequenceParser.test.ts +10 -12
  237. package/src/hasExecutable.ts +2 -2
  238. package/src/highResolutionTimer.ts +1 -1
  239. package/src/index.ts +113 -2
  240. package/src/inputReader.test.ts +39 -52
  241. package/src/inputReader.ts +2 -4
  242. package/src/inputReaderState.ts +1 -1
  243. package/src/inspect.ts +1 -1
  244. package/src/javaKeyStoreParser.test.ts +12 -14
  245. package/src/javaKeyStoreParser.ts +2 -6
  246. package/src/jsonParser.test.ts +2 -4
  247. package/src/jsonParser.ts +34 -38
  248. package/src/lazyMessageError.test.ts +21 -0
  249. package/src/lazyMessageError.ts +88 -0
  250. package/src/leb128Parser.test.ts +25 -23
  251. package/src/leb128Parser.ts +19 -19
  252. package/src/negativeLookaheadParser.test.ts +7 -11
  253. package/src/negativeLookaheadParser.ts +2 -2
  254. package/src/noStackCaptureOverheadError.test.ts +17 -0
  255. package/src/noStackCaptureOverheadError.ts +12 -0
  256. package/src/nonEmptyArrayParser.test.ts +3 -2
  257. package/src/nonEmptyArrayParser.ts +2 -2
  258. package/src/optionalParser.ts +2 -2
  259. package/src/parser.test.ts +96 -43
  260. package/src/parser.test.ts.md +13 -6
  261. package/src/parser.test.ts.snap +0 -0
  262. package/src/parser.ts +35 -12
  263. package/src/parserAccessorParser.ts +1 -1
  264. package/src/parserConsumedSequenceParser.ts +3 -3
  265. package/src/parserContext.test.ts +7 -3
  266. package/src/parserContext.ts +82 -48
  267. package/src/parserError.ts +143 -63
  268. package/src/parserImplementationInvariant.ts +3 -3
  269. package/src/parserInputCompanion.ts +2 -2
  270. package/src/promiseCompose.ts +2 -2
  271. package/src/regexpParser.test.ts +186 -0
  272. package/src/regexpParser.ts +94 -0
  273. package/src/regularExpression.ts +24 -0
  274. package/src/regularExpressionParser.test.ts +102 -0
  275. package/src/regularExpressionParser.ts +921 -0
  276. package/src/separatedArrayParser.ts +3 -3
  277. package/src/separatedNonEmptyArrayParser.test.ts +117 -0
  278. package/src/separatedNonEmptyArrayParser.ts +61 -0
  279. package/src/sequenceBuffer.test.ts +9 -9
  280. package/src/sequenceBuffer.ts +4 -4
  281. package/src/sequenceTerminatedSequenceParser.test.ts +3 -5
  282. package/src/sequenceTerminatedSequenceParser.ts +4 -4
  283. package/src/sequenceUnparser.ts +2 -2
  284. package/src/skipToParser.ts +2 -2
  285. package/src/sliceBoundedParser.test.ts +4 -12
  286. package/src/sliceBoundedParser.ts +2 -2
  287. package/src/smali.ts +8 -3
  288. package/src/smaliParser.test.ts +377 -66
  289. package/src/smaliParser.test.ts.md +1635 -48
  290. package/src/smaliParser.test.ts.snap +0 -0
  291. package/src/smaliParser.ts +2751 -569
  292. package/src/stringFromAsyncIterable.ts +9 -0
  293. package/src/terminatedArrayParser.test.ts +11 -11
  294. package/src/terminatedArrayParser.ts +5 -7
  295. package/src/toAsyncIterator.ts +8 -8
  296. package/src/uint8Array.ts +2 -3
  297. package/src/unionParser.test.ts +22 -23
  298. package/src/unionParser.ts +6 -8
  299. package/src/unparser.test.ts +18 -34
  300. package/src/unparser.ts +13 -9
  301. package/src/unparserContext.ts +9 -13
  302. package/src/unparserError.ts +2 -1
  303. package/src/unparserImplementationInvariant.ts +1 -1
  304. package/src/unparserOutputCompanion.ts +1 -1
  305. package/src/zip.ts +2 -6
  306. package/src/zipParser.ts +10 -18
  307. package/src/zipUnparser.test.ts +1 -1
  308. package/src/zipUnparser.ts +52 -64
  309. package/tsconfig.json +7 -1
  310. package/xo.config.ts +15 -0
  311. package/.yarn/releases/yarn-4.5.3.cjs +0 -934
@@ -0,0 +1,149 @@
1
+ # Copilot Instructions for @futpib/parser
2
+
3
+ ## Project Overview
4
+
5
+ This is a TypeScript library for parsing binary data formats, including:
6
+ - Android packages (APK files)
7
+ - Dalvik Executable (DEX) files
8
+ - Java KeyStore files
9
+ - ZIP archives
10
+ - BSON documents
11
+ - Smali bytecode
12
+
13
+ The library provides a functional, composable parser combinator framework built on top of async iterables for streaming binary data parsing.
14
+
15
+ ## Technology Stack
16
+
17
+ - **Language**: TypeScript (ES2022 target, NodeNext modules)
18
+ - **Build Tool**: TypeScript compiler (`tsc`)
19
+ - **Package Manager**: Yarn 4.9.4 (with Plug'n'Play)
20
+ - **Test Framework**: AVA with `@ava/typescript`
21
+ - **Test Coverage**: c8
22
+ - **Linter**: xo with TypeScript support
23
+ - **Key Dependencies**: fp-ts, monocle-ts, newtype-ts (functional programming libraries)
24
+
25
+ ## Project Structure
26
+
27
+ ```
28
+ src/
29
+ ├── parser.ts # Core parser types and runner
30
+ ├── parserContext.ts # Parser execution context
31
+ ├── unparser.ts # Core unparser (serializer) types
32
+ ├── *Parser.ts # Individual parser implementations
33
+ ├── *Unparser.ts # Individual unparser implementations
34
+ ├── *.test.ts # Test files (AVA)
35
+ build/ # Compiled output (generated)
36
+ ```
37
+
38
+ ## Build and Test Commands
39
+
40
+ ```bash
41
+ # Install dependencies
42
+ yarn install
43
+
44
+ # Build the project
45
+ yarn build
46
+
47
+ # Run tests with coverage
48
+ yarn test
49
+
50
+ # Watch mode for development
51
+ yarn dev
52
+
53
+ # Lint code
54
+ yarn xo
55
+ ```
56
+
57
+ ## Coding Conventions
58
+
59
+ ### Style Guidelines
60
+
61
+ - **Indentation**: Use tabs for indentation (configured in `.editorconfig`)
62
+ - **Line Endings**: LF (Unix-style)
63
+ - **Imports**: Always use `.js` extension in imports (ES module requirement)
64
+ - **Strict Mode**: TypeScript strict mode is enabled
65
+ - **Module System**: ES modules (type: "module" in package.json)
66
+
67
+ ### TypeScript Patterns
68
+
69
+ - Use functional programming patterns from `fp-ts` library
70
+ - Leverage TypeScript's type system extensively
71
+ - Prefer type inference where possible
72
+ - Use generics for parser combinators
73
+ - Follow existing naming patterns:
74
+ - Parser types: `Parser<Output, Sequence, Element>`
75
+ - Parser creators: `create*Parser()`
76
+ - Parser runners: `runParser()`
77
+
78
+ ### Parser Architecture
79
+
80
+ The library uses a parser combinator approach:
81
+ - Parsers are functions that take a `ParserContext` and return parsed output
82
+ - Parsers work with async iterables for streaming
83
+ - Use `InputReader` for lookahead and backtracking
84
+ - Compose parsers using combinator functions like:
85
+ - `createArrayParser()` - Parse arrays
86
+ - `createTupleParser()` - Parse tuples
87
+ - `createUnionParser()` - Try multiple parsers
88
+ - `createOptionalParser()` - Parse optional values
89
+ - `createExactSequenceParser()` - Parse exact byte sequences
90
+
91
+ ## Testing Approach
92
+
93
+ - Tests are co-located with source files (`.test.ts` suffix)
94
+ - Use AVA test framework with TypeScript support
95
+ - Tests run against the compiled `build/` directory
96
+ - Property-based testing with `fast-check` for parsers
97
+ - Snapshot testing for complex data structures
98
+ - Some tests use external binary files (referenced by CID hashes)
99
+ - Test files may have corresponding `.md` and `.snap` files
100
+
101
+ ### Running Tests
102
+
103
+ ```bash
104
+ # Run all tests
105
+ yarn test
106
+
107
+ # Tests are verbose by default (configured in package.json)
108
+ # Coverage is collected automatically with c8
109
+ ```
110
+
111
+ ## Key Architectural Decisions
112
+
113
+ 1. **Async Iterables**: All parsers work with async iterables to support streaming large files
114
+ 2. **Functional Style**: Heavy use of fp-ts for functional composition
115
+ 3. **Type Safety**: Extensive use of TypeScript generics to ensure type safety
116
+ 4. **Parser Combinators**: Build complex parsers from simple building blocks
117
+ 5. **Unparsers**: Support bidirectional serialization/deserialization
118
+
119
+ ## Dependencies to Know
120
+
121
+ - `fp-ts`: Functional programming library for TypeScript
122
+ - `monocle-ts`: Optics library for working with immutable data
123
+ - `newtype-ts`: Newtype pattern for type-safe wrappers
124
+ - `p-mutex`: Promise-based mutex for concurrency control
125
+ - `mutf-8`: Modified UTF-8 encoding (peer dependency, optional)
126
+
127
+ ## Common Tasks
128
+
129
+ ### Adding a New Parser
130
+
131
+ 1. Create `src/myParser.ts` with parser implementation
132
+ 2. Export `createMyParser()` function
133
+ 3. Add corresponding test file `src/myParser.test.ts`
134
+ 4. Export from `src/index.ts` if part of public API
135
+ 5. Run tests and build to verify
136
+
137
+ ### Debugging Tests
138
+
139
+ - Tests output verbose information by default
140
+ - Check `.snap` files for expected outputs
141
+ - Some tests may be skipped (e.g., tests requiring large binary files)
142
+ - Pre-existing test failures are acceptable if unrelated to your changes
143
+
144
+ ## Notes
145
+
146
+ - The project uses Yarn Plug'n'Play (no `node_modules` directory)
147
+ - License: GPL-3.0-only
148
+ - Some tests download or reference external binary files via IPFS CID hashes
149
+ - Coverage reports are sent to Coveralls in CI
@@ -0,0 +1,18 @@
1
+ name: Copilot Setup Steps
2
+ on:
3
+ workflow_dispatch:
4
+ jobs:
5
+ copilot-setup-steps:
6
+ name: Setup smali and baksmali
7
+ runs-on: ubuntu-latest
8
+ permissions: {}
9
+ steps:
10
+ - uses: actions/checkout@v4
11
+ - name: Install system dependencies
12
+ run: |
13
+ sudo apt-get update
14
+ sudo apt-get install -y libsmali-java
15
+ - uses: actions/setup-node@v4
16
+ with:
17
+ node-version: 24
18
+ - run: yarn install
@@ -1,7 +1,9 @@
1
1
  name: CI
2
2
  on:
3
- - push
4
- - pull_request
3
+ push:
4
+ branches:
5
+ - master
6
+ pull_request:
5
7
  jobs:
6
8
  test:
7
9
  name: Node.js ${{ matrix.node-version }}
@@ -11,18 +13,37 @@ jobs:
11
13
  matrix:
12
14
  node-version:
13
15
  - 22
14
- - 20
15
- - 18
16
+ - 24
16
17
  steps:
17
- - uses: actions/checkout@v2
18
- - uses: actions/setup-node@v2
18
+ - uses: actions/checkout@v4
19
+ with:
20
+ fetch-depth: 1
21
+ - name: Cache and install libsmali-java
22
+ uses: awalsh128/cache-apt-pkgs-action@latest
23
+ with:
24
+ packages: libsmali-java
25
+ version: 1.0
26
+ - uses: actions/setup-node@v4
19
27
  with:
20
28
  node-version: ${{ matrix.node-version }}
21
- - run: yarn install
29
+ - name: Get yarn cache directory path
30
+ id: yarn-cache-dir-path
31
+ run: echo "dir=$(yarn config get cacheFolder)" >> $GITHUB_OUTPUT
32
+ - name: Cache yarn cache
33
+ uses: actions/cache@v4
34
+ with:
35
+ path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
36
+ key: yarn-cache-${{ runner.os }}-${{ hashFiles('**/yarn.lock', '.yarnrc.yml') }}
37
+ restore-keys: |
38
+ yarn-cache-${{ runner.os }}-
39
+ - run: yarn install --immutable
22
40
  - run: yarn build
23
41
  - run: yarn test
24
- - run: yarn c8 report --reporter=lcovonly
42
+ - name: Generate coverage report
43
+ if: matrix.node-version == 24
44
+ run: yarn c8 report --reporter=lcovonly
25
45
  - name: Coveralls
46
+ if: matrix.node-version == 24
26
47
  uses: coverallsapp/github-action@v2
27
48
  with:
28
49
  github-token: ${{ secrets.GITHUB_TOKEN }}