mirror of
https://github.com/status-im/sourcecred.git
synced 2025-01-27 12:55:14 +00:00
417cc231e9
Summary: I selected this over the alternatives, `sqlite` and `sqlite3`, primarily because its README explicitly acknowledges that using asynchronous APIs for CPU-bound or serialized work units are worse than useless. To me, this is a sign that the maintainer has his head on straight. The many-fold performance increase over `sqlite` and `sqlite3` is nice to have, too. For now, we use my fork of the project, which includes a critical patch to support private in-memory databases via SQLite’s standard `:memory:` filepath. When this patch is merged upstream, we can move back to mainline. Test Plan: The following session demonstrates the basic API and validates that the install has completed successfully: ```js const Database = require("better-sqlite3"); const db = new Database("/tmp/irrelevant", {memory: true}); db.prepare("CREATE TABLE pythagorean_triples (x, y, z)").run(); const insert = db.prepare("INSERT INTO pythagorean_triples VALUES (?, ?, ?)"); const get = db.prepare( "SELECT rowid, x * x + y * y AS xxyy, z * z AS zz FROM pythagorean_triples" ); function print(x) { console.log(JSON.stringify(x)); } print(insert.run(3, 4, 5)); print(get.all()); print(insert.run(5, 12, 13)); print(get.all()); db.prepare("DELETE FROM pythagorean_triples").run(); print(get.all()); ``` It prints: ```js {"changes":1,"lastInsertROWID":1} [{"rowid":1,"xxyy":25,"zz":25}] {"changes":1,"lastInsertROWID":2} [{"rowid":1,"xxyy":25,"zz":25},{"rowid":2,"xxyy":169,"zz":169}] [] ``` wchargin-branch: dep-better-sqlite3
124 lines
3.6 KiB
JSON
124 lines
3.6 KiB
JSON
{
|
|
"name": "sourcecred",
|
|
"version": "0.1.0",
|
|
"private": true,
|
|
"dependencies": {
|
|
"aphrodite": "^2.1.0",
|
|
"better-sqlite3": "wchargin/better-sqlite3#wchargin-private-inmemory-db",
|
|
"chalk": "1.1.3",
|
|
"commonmark": "^0.28.1",
|
|
"express": "^4.16.3",
|
|
"fs-extra": "3.0.1",
|
|
"history": "^3.0.0",
|
|
"isomorphic-fetch": "^2.2.1",
|
|
"json-stable-stringify": "^1.0.1",
|
|
"lodash.clonedeep": "^4.5.0",
|
|
"lodash.isequal": "^4.5.0",
|
|
"lodash.sortby": "^4.7.0",
|
|
"mkdirp": "^0.5.1",
|
|
"object-assign": "4.1.1",
|
|
"pako": "^1.0.6",
|
|
"promise": "8.0.1",
|
|
"react": "^16.4.1",
|
|
"react-dom": "^16.4.1",
|
|
"react-router": "3.2.1",
|
|
"retry": "^0.12.0",
|
|
"tmp": "^0.0.33",
|
|
"whatwg-fetch": "2.0.3"
|
|
},
|
|
"devDependencies": {
|
|
"babel-core": "6.26.0",
|
|
"babel-eslint": "7.2.3",
|
|
"babel-jest": "20.0.3",
|
|
"babel-loader": "7.1.2",
|
|
"babel-plugin-transform-es2015-for-of": "^6.23.0",
|
|
"babel-preset-react-app": "^3.1.1",
|
|
"babel-runtime": "6.26.0",
|
|
"copy-webpack-plugin": "^4.5.2",
|
|
"css-loader": "0.28.7",
|
|
"dotenv": "4.0.0",
|
|
"dotenv-expand": "4.0.1",
|
|
"enzyme": "^3.3.0",
|
|
"enzyme-adapter-react-16": "^1.1.1",
|
|
"enzyme-to-json": "^3.3.3",
|
|
"eslint": "4.10.0",
|
|
"eslint-config-react-app": "^2.1.0",
|
|
"eslint-plugin-flowtype": "2.39.1",
|
|
"eslint-plugin-import": "2.8.0",
|
|
"eslint-plugin-jsx-a11y": "5.1.1",
|
|
"eslint-plugin-react": "7.4.0",
|
|
"file-loader": "1.1.5",
|
|
"flow-bin": "^0.80.0",
|
|
"jest": "23.4.1",
|
|
"jest-fetch-mock": "^1.6.5",
|
|
"prettier": "^1.13.4",
|
|
"raf": "3.4.0",
|
|
"react-dev-utils": "^5.0.0",
|
|
"static-site-generator-webpack-plugin": "^3.4.1",
|
|
"url-loader": "0.6.2",
|
|
"webpack": "3.8.1",
|
|
"webpack-dev-server": "2.9.4",
|
|
"webpack-manifest-plugin": "1.3.2",
|
|
"webpack-node-externals": "^1.7.2"
|
|
},
|
|
"scripts": {
|
|
"prettify": "prettier --write '**/*.js'",
|
|
"check-pretty": "prettier --list-different '**/*.js'",
|
|
"start": "NODE_ENV=development webpack-dev-server --config config/webpack.config.web.js",
|
|
"build": "NODE_ENV=production webpack --config config/webpack.config.web.js",
|
|
"backend": "NODE_ENV=development webpack --config config/webpack.config.backend.js",
|
|
"test": "node ./config/test.js",
|
|
"unit": "BABEL_ENV=test NODE_ENV=test jest --env=jsdom",
|
|
"sharness": "make -sC ./sharness prove PROVE_OPTS=-f TEST_OPTS='--chain-lint'",
|
|
"sharness-full": "make -sC ./sharness prove PROVE_OPTS=-f TEST_OPTS='--chain-lint --long'",
|
|
"coverage": "npm run unit -- --coverage",
|
|
"flow": "flow",
|
|
"lint": "eslint src config --max-warnings 0"
|
|
},
|
|
"license": "MIT",
|
|
"jest": {
|
|
"collectCoverageFrom": [
|
|
"src/**/*.{js,jsx,mjs}"
|
|
],
|
|
"setupFiles": [
|
|
"<rootDir>/config/polyfills.js",
|
|
"<rootDir>/config/jest/setupJest.js"
|
|
],
|
|
"testMatch": [
|
|
"<rootDir>/src/**/__tests__/**/*.{js,jsx,mjs}",
|
|
"<rootDir>/src/**/?(*.)(spec|test).{js,jsx,mjs}"
|
|
],
|
|
"testEnvironment": "node",
|
|
"testURL": "http://localhost",
|
|
"transform": {
|
|
"^.+\\.(js|jsx|mjs)$": "<rootDir>/node_modules/babel-jest",
|
|
"^.+\\.css$": "<rootDir>/config/jest/cssTransform.js",
|
|
"^(?!.*\\.(js|jsx|mjs|css|json)$)": "<rootDir>/config/jest/fileTransform.js"
|
|
},
|
|
"transformIgnorePatterns": [
|
|
"[/\\\\]node_modules[/\\\\].+\\.(js|jsx|mjs)$"
|
|
],
|
|
"moduleNameMapper": {
|
|
"^react-native$": "react-native-web"
|
|
},
|
|
"moduleFileExtensions": [
|
|
"web.js",
|
|
"mjs",
|
|
"js",
|
|
"json",
|
|
"web.jsx",
|
|
"jsx",
|
|
"node"
|
|
]
|
|
},
|
|
"babel": {
|
|
"presets": [
|
|
"./config/babel"
|
|
]
|
|
},
|
|
"files": [
|
|
"/bin",
|
|
"/build"
|
|
]
|
|
}
|