GitXplorerGitXplorer
m

PunQLite

public
12 stars
4 forks
1 issues

Commits

List of commits on branch master.
Verified
aab064c2e003ef18fcdf8dad2a139fa4b36b6ed6

Merge pull request #3 from sebastianconcept/remove-binaries-support

mmumez committed 3 years ago
Unverified
7a86e9f9daf4faa040b6340b0fde8d6ea0a789e8

removes unsupported files, readme edit

committed 3 years ago
Unverified
2ffc6ba3f66d9dad668ae9f73c7acdeb25d4f683

Removes Tools from default so it can be loaded in Pharo 10

committed 3 years ago
Unverified
45be6e06c80c8f09b48a8d2ae16b3312a0321ed5

Removes preLoad of binaries from Baseline and latest Configuration

committed 3 years ago
Unverified
6ee1bf699f43c037c038c0647bd12e4f942c60dd

Updated to add -static-libgcc option for Windows dll build

mmumez committed 8 years ago
Unverified
c95147f7595e051eeee3337a3eed8afa35274030

Updated #platformLibraryUrl to download the latest precompiled unqlite library

mmumez committed 9 years ago

README

The README file for this repository.

PunQLite Build Status

UnQLite binding for Pharo Smalltalk. UnQLite is a fast, lightweight, portable, embedded KVS with a simple scripting engine (Jx9). By using PunQLite, you can store/load lots of data as if just using a normal Dictionary.

Release Tests License

Social Forks

Directories:

  • repository
  • Cypress style Smalltalk source tree

For MCZ packages, visit SmalltalkHub PunQLite site.

Installation

  • Compile UnQLite

It would be very easy. UnQLite consists of only two files.

gcc -m32 -c unqlite.c

#linux
gcc -m32 -shared -o unqlite.so unqlite.o

#win (MinGW)
gcc -m32 -shared -static-libgcc -o unqlite.dll unqlite.o -Wl,--add-stdcall-alias

#mac
gcc -m32 -dynamiclib -o unqlite.dylib unqlite.o
  • Load PunQLite
Metacello new 
	repository: 'github://mumez/PunQLite/repository';
	baseline: 'PunQLite';
	load.

Performance

"Simple store/load round-trip"
Time millisecondsToRun:[
db := PqDatabase open: 'bench.db'.
val := '0'.
1 to: 100000 do: [:idx | | key | 
	key := idx asString.
	db at: key put: val.
	val := (db at: key) asString.
].
db close.
]. "===> 877 msecs"

I felt it is quite fast. 100000 round-trips in 877 msecs. Please try the code by yourself.

Usages

"Like a Dictionary"
db := PqDatabase openOnMemory.
db at: 'Smalltalk' put: 'COOL'.
db at: 'Pharo' put: 'HOT'.
db at: 'Smalltalk' ifPresent: [:data |
	data asString inspect
].
Transcript cr; show: db keys.
db do: [:cursor |
	Transcript cr; show: cursor currentStringKey; space; show: cursor currentStringValue.		
].
db close.
"Using explicit transaction"
db := PqDatabase open: 'trans.db'.
db disableAutoCommit.
1 to: 100 do: [:idx | | key | 
	key := idx asString.
	db transact: [db at: key put: ('value-', key)]
].
db close.
"Using cursor seek"
db := PqDatabase openOnMemory.
1 to: 10 do: [:idx |
	db at: idx asString put: 'value-', idx asString.
].
cursor := db newCursor.
entries := OrderedCollection new.
cursor seek: '5' untilEndDo: [:cur |
	entries add: (cur currentStringKey -> cur currentStringValue)	
].
cursor close.
db close.
^entries "==> an OrderedCollection('5'->'value-5' '6'->'value-6' '7'->'value-7' '8'->'value-8' '9'->'value-9' '10'->'value-10')"
"Import from files"
db := PqDatabase open: 'mczCache.db'.
(FileSystem workingDirectory / 'package-cache') files do: [:each | 
	(db importAt: each basename fromFile: each pathString)
		 ifTrue: [db commitTransaction].
].
db keys inspect.
db close.
"Excute Jx9 scripting language"
db := PqDatabase openOnMemory.
src := '
	$var = 123;
	$str = "$var - one, two, three!";
	$tm = time();
	'.
executer := db jx9.
executer evaluate: src.
(executer extract: 'var') asInt inspect.
(executer extract: 'str') asString inspect. 
(executer extract: 'tm') asInt inspect.
executer release.
db close.