Compare commits

...

10 Commits

11 changed files with 4172 additions and 4103 deletions
+1
View File
@@ -0,0 +1 @@
/cache
+68
View File
@@ -0,0 +1,68 @@
# language of the project (csharp, python, rust, java, typescript, go, cpp, or ruby)
# * For C, use cpp
# * For JavaScript, use typescript
# Special requirements:
# * csharp: Requires the presence of a .sln file in the project folder.
language: typescript
# whether to use the project's gitignore file to ignore files
# Added on 2025-04-07
ignore_all_files_in_gitignore: true
# list of additional paths to ignore
# same syntax as gitignore, so you can use * and **
# Was previously called `ignored_dirs`, please update your config if you are using that.
# Added (renamed) on 2025-04-07
ignored_paths: []
# whether the project is in read-only mode
# If set to true, all editing tools will be disabled and attempts to use them will result in an error
# Added on 2025-04-18
read_only: false
# list of tool names to exclude. We recommend not excluding any tools, see the readme for more details.
# Below is the complete list of tools for convenience.
# To make sure you have the latest list of tools, and to view their descriptions,
# execute `uv run scripts/print_tool_overview.py`.
#
# * `activate_project`: Activates a project by name.
# * `check_onboarding_performed`: Checks whether project onboarding was already performed.
# * `create_text_file`: Creates/overwrites a file in the project directory.
# * `delete_lines`: Deletes a range of lines within a file.
# * `delete_memory`: Deletes a memory from Serena's project-specific memory store.
# * `execute_shell_command`: Executes a shell command.
# * `find_referencing_code_snippets`: Finds code snippets in which the symbol at the given location is referenced.
# * `find_referencing_symbols`: Finds symbols that reference the symbol at the given location (optionally filtered by type).
# * `find_symbol`: Performs a global (or local) search for symbols with/containing a given name/substring (optionally filtered by type).
# * `get_current_config`: Prints the current configuration of the agent, including the active and available projects, tools, contexts, and modes.
# * `get_symbols_overview`: Gets an overview of the top-level symbols defined in a given file.
# * `initial_instructions`: Gets the initial instructions for the current project.
# Should only be used in settings where the system prompt cannot be set,
# e.g. in clients you have no control over, like Claude Desktop.
# * `insert_after_symbol`: Inserts content after the end of the definition of a given symbol.
# * `insert_at_line`: Inserts content at a given line in a file.
# * `insert_before_symbol`: Inserts content before the beginning of the definition of a given symbol.
# * `list_dir`: Lists files and directories in the given directory (optionally with recursion).
# * `list_memories`: Lists memories in Serena's project-specific memory store.
# * `onboarding`: Performs onboarding (identifying the project structure and essential tasks, e.g. for testing or building).
# * `prepare_for_new_conversation`: Provides instructions for preparing for a new conversation (in order to continue with the necessary context).
# * `read_file`: Reads a file within the project directory.
# * `read_memory`: Reads the memory with the given name from Serena's project-specific memory store.
# * `remove_project`: Removes a project from the Serena configuration.
# * `replace_lines`: Replaces a range of lines within a file with new content.
# * `replace_symbol_body`: Replaces the full definition of a symbol.
# * `restart_language_server`: Restarts the language server, may be necessary when edits not through Serena happen.
# * `search_for_pattern`: Performs a search for a pattern in the project.
# * `summarize_changes`: Provides instructions for summarizing the changes made to the codebase.
# * `switch_modes`: Activates modes by providing a list of their names
# * `think_about_collected_information`: Thinking tool for pondering the completeness of collected information.
# * `think_about_task_adherence`: Thinking tool for determining whether the agent is still on track with the current task.
# * `think_about_whether_you_are_done`: Thinking tool for determining whether the task is truly completed.
# * `write_memory`: Writes a named memory (for future reference) to Serena's project-specific memory store.
excluded_tools: []
# initial prompt for the project. It will always be given to the LLM upon activating the project
# (contrary to the memories, which are loaded on demand).
initial_prompt: ""
project_name: "smarthash"
+14 -23
View File
@@ -1,5 +1,5 @@
{ {
"gitzone": { "@git.zone/cli": {
"projectType": "npm", "projectType": "npm",
"module": { "module": {
"githost": "code.foss.global", "githost": "code.foss.global",
@@ -8,29 +8,20 @@
"description": "Cross-environment hash functions (SHA256 and MD5) for Node.js and browsers, with support for strings, streams, and files.", "description": "Cross-environment hash functions (SHA256 and MD5) for Node.js and browsers, with support for strings, streams, and files.",
"npmPackagename": "@push.rocks/smarthash", "npmPackagename": "@push.rocks/smarthash",
"license": "MIT", "license": "MIT",
"keywords": [ "projectDomain": "push.rocks"
"crypto", },
"hashing", "release": {
"SHA256", "registries": [
"MD5", "https://verdaccio.lossless.digital",
"security", "https://registry.npmjs.org"
"node.js", ],
"browser", "accessLevel": "public"
"cross-environment",
"web crypto",
"stream hashing",
"file hashing",
"synchronous hashing",
"asynchronous hashing",
"data integrity",
"typescript"
]
} }
}, },
"npmci": { "@git.zone/tsdoc": {
"npmAccessLevel": "public"
},
"tsdoc": {
"legal": "\n## License and Legal Information\n\nThis repository contains open-source code that is licensed under the MIT License. A copy of the MIT License can be found in the [license](license) file within this repository. \n\n**Please note:** The MIT License does not grant permission to use the trade names, trademarks, service marks, or product names of the project, except as required for reasonable and customary use in describing the origin of the work and reproducing the content of the NOTICE file.\n\n### Trademarks\n\nThis project is owned and maintained by Task Venture Capital GmbH. The names and logos associated with Task Venture Capital GmbH and any related products or services are trademarks of Task Venture Capital GmbH and are not included within the scope of the MIT license granted herein. Use of these trademarks must comply with Task Venture Capital GmbH's Trademark Guidelines, and any usage must be approved in writing by Task Venture Capital GmbH.\n\n### Company Information\n\nTask Venture Capital GmbH \nRegistered at District court Bremen HRB 35230 HB, Germany\n\nFor any legal inquiries or if you require further information, please contact us via email at hello@task.vc.\n\nBy using this repository, you acknowledge that you have read this section, agree to comply with its terms, and understand that the licensing of the code does not imply endorsement by Task Venture Capital GmbH of any derivative works.\n" "legal": "\n## License and Legal Information\n\nThis repository contains open-source code that is licensed under the MIT License. A copy of the MIT License can be found in the [license](license) file within this repository. \n\n**Please note:** The MIT License does not grant permission to use the trade names, trademarks, service marks, or product names of the project, except as required for reasonable and customary use in describing the origin of the work and reproducing the content of the NOTICE file.\n\n### Trademarks\n\nThis project is owned and maintained by Task Venture Capital GmbH. The names and logos associated with Task Venture Capital GmbH and any related products or services are trademarks of Task Venture Capital GmbH and are not included within the scope of the MIT license granted herein. Use of these trademarks must comply with Task Venture Capital GmbH's Trademark Guidelines, and any usage must be approved in writing by Task Venture Capital GmbH.\n\n### Company Information\n\nTask Venture Capital GmbH \nRegistered at District court Bremen HRB 35230 HB, Germany\n\nFor any legal inquiries or if you require further information, please contact us via email at hello@task.vc.\n\nBy using this repository, you acknowledge that you have read this section, agree to comply with its terms, and understand that the licensing of the code does not imply endorsement by Task Venture Capital GmbH of any derivative works.\n"
},
"@ship.zone/szci": {
"npmGlobalTools": []
} }
} }
+38
View File
@@ -1,5 +1,43 @@
# Changelog # Changelog
## 2026-04-30 - 3.2.7 - fix(build)
migrate project metadata to .smartconfig and tighten TypeScript build settings
- replace npmextra.json with .smartconfig.json and update packaged config file references
- upgrade build and test toolchain dependencies along with related package versions
- remove the build flag that allowed implicit any and enforce noImplicitAny in tsconfig
- add repository issue tracker metadata and refresh package manager version
## 2025-09-12 - 3.2.6 - fix(ci)
Add .claude local settings to permit web fetch to www.npmjs.com
- Added .claude/settings.local.json granting WebFetch permission for www.npmjs.com
- Configuration-only change; no runtime or library code modified
## 2025-09-12 - 3.2.5 - fix(ts_web)
Ensure sha256FromBuffer uses correct ArrayBuffer slice for Uint8Array inputs and add local project config files
- Fix sha256FromBuffer in ts_web: explicitly slice Uint8Array.buffer using byteOffset/byteLength before calling crypto.subtle.digest to ensure the correct ArrayBuffer segment is hashed in browser environments.
- Add .claude/settings.local.json to allow WebFetch to www.npmjs.com for local tooling.
- Add .serena/.gitignore and .serena/project.yml to include project-specific configuration and ignored cache path.
- Add missing newline at end of ts_web/index.ts
## 2025-09-12 - 3.2.4 - fix(deps)
Bump devDependencies, update smartjson and add workspace/CI settings
- Bump @git.zone/tsbuild from ^2.1.70 to ^2.6.8
- Bump @git.zone/tstest from ^2.3.2 to ^2.3.8
- Bump @push.rocks/smartjson from ^5.0.10 to ^5.2.0
- Add pnpm-workspace.yaml with onlyBuiltDependencies: esbuild, mongodb-memory-server, puppeteer
- Add .claude/settings.local.json to allow WebFetch access to www.npmjs.com
## 2025-08-03 - 3.2.3 - fix(dependencies/config)
Update dependency versions and add local settings for web fetch configuration
- Bump @git.zone/tstest from ^1.0.81 to ^2.3.2
- Bump @push.rocks/smartenv from ^5.0.5 to ^5.0.13
- Add .claude/settings.local.json to allow WebFetch permissions for www.npmjs.com
## 2025-08-03 - 3.2.1 - docs(readme) ## 2025-08-03 - 3.2.1 - docs(readme)
Enhance readme with comprehensive documentation and modern formatting Enhance readme with comprehensive documentation and modern formatting
+16 -13
View File
@@ -1,6 +1,6 @@
{ {
"name": "@push.rocks/smarthash", "name": "@push.rocks/smarthash",
"version": "3.2.2", "version": "3.2.7",
"private": false, "private": false,
"description": "Cross-environment hash functions (SHA256 and MD5) for Node.js and browsers, with support for strings, streams, and files.", "description": "Cross-environment hash functions (SHA256 and MD5) for Node.js and browsers, with support for strings, streams, and files.",
"exports": { "exports": {
@@ -9,7 +9,7 @@
}, },
"scripts": { "scripts": {
"test": "(tstest test/ --web)", "test": "(tstest test/ --web)",
"build": "(tsbuild tsfolders --allowimplicitany)", "build": "tsbuild tsfolders",
"buildDocs": "tsdoc" "buildDocs": "tsdoc"
}, },
"keywords": [ "keywords": [
@@ -29,19 +29,19 @@
"data integrity", "data integrity",
"typescript" "typescript"
], ],
"author": "Lossless GmbH", "author": "Task Venture Capital GmbH",
"license": "MIT", "license": "MIT",
"devDependencies": { "devDependencies": {
"@git.zone/tsbuild": "^2.1.70", "@git.zone/tsbuild": "^4.4.0",
"@git.zone/tsrun": "^1.2.46", "@git.zone/tsrun": "^2.0.2",
"@git.zone/tstest": "^1.0.81", "@git.zone/tstest": "^3.6.3",
"@types/node": "^20.6.3" "@types/node": "^25.6.0"
}, },
"dependencies": { "dependencies": {
"@push.rocks/smartenv": "^5.0.5", "@push.rocks/smartenv": "^6.0.0",
"@push.rocks/smartjson": "^5.0.10", "@push.rocks/smartjson": "^6.0.1",
"@push.rocks/smartpromise": "^4.0.3", "@push.rocks/smartpromise": "^4.2.3",
"@types/through2": "^2.0.39", "@types/through2": "^2.0.41",
"through2": "^4.0.2" "through2": "^4.0.2"
}, },
"files": [ "files": [
@@ -53,7 +53,7 @@
"dist_ts_web/**/*", "dist_ts_web/**/*",
"assets/**/*", "assets/**/*",
"cli.js", "cli.js",
"npmextra.json", ".smartconfig.json",
"readme.md" "readme.md"
], ],
"browserslist": [ "browserslist": [
@@ -65,5 +65,8 @@
"type": "git", "type": "git",
"url": "https://code.foss.global/push.rocks/smarthash.git" "url": "https://code.foss.global/push.rocks/smarthash.git"
}, },
"packageManager": "pnpm@10.11.0+sha512.6540583f41cc5f628eb3d9773ecee802f4f9ef9923cc45b69890fb47991d4b092964694ec3a4f738a420c918a333062c8b925d312f42e4f0c263eb603551f977" "bugs": {
"url": "https://code.foss.global/push.rocks/smarthash/issues"
},
"packageManager": "pnpm@10.28.2"
} }
+4013 -4062
View File
File diff suppressed because it is too large Load Diff
+4
View File
@@ -0,0 +1,4 @@
onlyBuiltDependencies:
- esbuild
- mongodb-memory-server
- puppeteer
+1 -1
View File
@@ -3,6 +3,6 @@
*/ */
export const commitinfo = { export const commitinfo = {
name: '@push.rocks/smarthash', name: '@push.rocks/smarthash',
version: '3.2.0', version: '3.2.7',
description: 'Cross-environment hash functions (SHA256 and MD5) for Node.js and browsers, with support for strings, streams, and files.' description: 'Cross-environment hash functions (SHA256 and MD5) for Node.js and browsers, with support for strings, streams, and files.'
} }
+1 -1
View File
@@ -3,6 +3,6 @@
*/ */
export const commitinfo = { export const commitinfo = {
name: '@push.rocks/smarthash', name: '@push.rocks/smarthash',
version: '3.2.0', version: '3.2.7',
description: 'Cross-environment hash functions (SHA256 and MD5) for Node.js and browsers, with support for strings, streams, and files.' description: 'Cross-environment hash functions (SHA256 and MD5) for Node.js and browsers, with support for strings, streams, and files.'
} }
+14 -2
View File
@@ -60,7 +60,19 @@ export const sha256FromStringSync = (stringArg: string): string => {
*/ */
export const sha256FromBuffer = async (bufferArg: ArrayBuffer | Uint8Array): Promise<string> => { export const sha256FromBuffer = async (bufferArg: ArrayBuffer | Uint8Array): Promise<string> => {
if (isCryptoSubtleAvailable()) { if (isCryptoSubtleAvailable()) {
const hash = await crypto.subtle.digest("SHA-256", bufferArg); // Ensure we pass an ArrayBuffer to satisfy BufferSource typing
let inputBuffer: ArrayBuffer;
if (bufferArg instanceof Uint8Array) {
const view = bufferArg;
inputBuffer = view.buffer.slice(
view.byteOffset,
view.byteOffset + view.byteLength
) as ArrayBuffer;
} else {
inputBuffer = bufferArg;
}
const hash = await crypto.subtle.digest("SHA-256", inputBuffer);
const result = hex(hash); const result = hex(hash);
return result; return result;
} else { } else {
@@ -101,4 +113,4 @@ export const sha256FromFile = async (filePath: string): Promise<string> => {
*/ */
export const md5FromString = async (stringToHash: string): Promise<string> => { export const md5FromString = async (stringToHash: string): Promise<string> => {
throw new Error('md5FromString is not supported in browser environment. Web Crypto API does not support MD5.'); throw new Error('md5FromString is not supported in browser environment. Web Crypto API does not support MD5.');
}; };
+2 -1
View File
@@ -6,7 +6,8 @@
"module": "NodeNext", "module": "NodeNext",
"moduleResolution": "NodeNext", "moduleResolution": "NodeNext",
"esModuleInterop": true, "esModuleInterop": true,
"verbatimModuleSyntax": true "verbatimModuleSyntax": true,
"noImplicitAny": true
}, },
"exclude": [ "exclude": [
"dist_*/**/*.d.ts" "dist_*/**/*.d.ts"