内容简介:This is a lightweight, fast, full-text search engine for static websites. I'm using it on
tinysearch
This is a lightweight, fast, full-text search engine for static websites. I'm using it on my blog :
It is a Rust/WASM port of the Python code from the article "Writing a full-text search engine using Bloom filters" . This can be seen as an alternative to lunr.js and elasticlunr .
The idea is to generate a small, self-contained WASM module from a list of articles on your website and ship it to browsers. tinysearch can be integrated into the build process of generators like Jekyll , Hugo , zola , or Cobalt .
Limitations
- Only searches for entire words. There are no search suggestions (yet).
- Since we bundle all search indices for all articles into one static binary, we recommend to only use it for small- to medium-size websites. Expect around 4kB (non-compressed) per article.
Installation
wasm-pack is required to build the WASM module. Install it with
cargo install wasm-pack
To optimize the JavaScript output, you'll also need terser :
npm install terser -g
If you want to make the WebAssembly as small as possible, we recommend to install binaryen as well. On macOS you can install it with homebrew :
brew install binaryen
Alternatively, you can download the binary from the release page or use your OS package manager.
After that, you can install tinysearch itself:
cargo install tinysearch
Usage
As an input, we require a JSON file, which contains a the content you like to index. Check out this example file ).
tinysearch fixtures/index.json
(You can take a look at the code examples for different static site generators here .)
This will create a WASM module and the JavaScript glue code to integrate it into your homepage. You can open the demo.html from any webserver to see the result.
For example, Python has a built-in webserver for testing:
python -m SimpleHTTPServer
then browse to http://0.0.0.0:8000/demo.html to see the result.
For advanced usage options, try
tinysearch --help
Maintainers
- Matthias Endler (@mre)
- Jorge-Luis Betancourt (@jorgelbg)
License
tinysearch is licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0 )
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT )
at your option.
以上所述就是小编给大家介绍的《A tiny, full-text search engine for static sites built with Rust and WASM》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深度探索C++对象模型
斯坦利•B.李普曼 (Stanley B. Lippman) / 侯捷 / 电子工业出版社 / 2012-1 / 69.00元
作者Lippman参与设计了全世界第一套C++编译程序cfront,这本书就是一位伟大的C++编译程序设计者向你阐述他如何处理各种explicit(明确出现于C++程序代码中)和implicit(隐藏于程序代码背后)的C++语意。 本书专注于C++面向对象程序设计的底层机制,包括结构式语意、临时性对象的生成、封装、继承,以及虚拟——虚拟函数和虚拟继承。这本书让你知道:一旦你能够了解底层实现模......一起来看看 《深度探索C++对象模型》 这本书的介绍吧!