GitXplorerGitXplorer
b

dinsd

public
2 stars
1 forks
0 issues

Commits

List of commits on branch master.
Unverified
ce722308254a9170afda5de6c6e48972e9557545

Fix update to work if there is no key.

bbitdancer committed 12 years ago
Unverified
db18b28958b6b8eebb5e0d484cfbbae8dcd23c36

Add test that insert/update/delete changes persist.

bbitdancer committed 12 years ago
Unverified
952907c1cc70a18cb9631fd690bb57bea82efe36

Allow types that do not except instances as input.

bbitdancer committed 12 years ago
Unverified
79703e024dded7a675376955a4545a63722fa259

Add some type guessing to extend.

bbitdancer committed 12 years ago
Unverified
28c45e006ba72686dde7b9e596106bed9a939349

Add 'prototype' arg to extend.

bbitdancer committed 12 years ago
Unverified
e7c374fc2bcab10edebbe1d70f78cd00d2eec609

Move _R to the db module.

bbitdancer committed 12 years ago

README

The README file for this repository.

dinsd: D Is Not Static D

This project (still in its early stages) is an attempt to turn Python into something D-like, where D is a theoretical construct envisioned by Hugh Darwen and C. J. Date (see http://www.thethirdmanifesto.com/). The goal is to have a computationally complete language that implements a full relational algebra as a first class citizen.

Python can never be a D, because D requires static typing and Python is dynamically typed. But Python plus the dinsd module does make the relational algebra a first class citizen, turning Python into Relational Python.

At this early stage of the project the persistence layer is just a backing store for what is otherwise an in-memory database. That is, all data for all tables is held in memory at all times, and written to disk only when something is updated.

Right now it is mostly useful as a tool for playing with relational algebra at the Python shell prompt. The goal, though, is to provide a smarter persistence layer (as well as other currently-missing DBMS features) such that it will be practical to use it in at least the contexts where an SQL engine like SQLite is currently used. Indeed, SQLite (which is used for the current persistence layer) will be the first smarter persistence layer, if everything goes well.

Currently there is no project infrastructure other than for running the tests ('make test' in the root directory). You can copy the package directory (src/dinsd) to wherever you want it in order to play with it. The only external requirement is sqlite3.

The documentation consists of literate test documents:

doc/relational_python.rst
doc/db_api.rst

which are evolving along with the code and so may not be completely internally consistent at any given checkin. The tests should always be passing, but the text may not be 100% consistent with itself if I'm in the middle of a major refactoring. Most of the time it should be, though, and the documents should therefore provide a thorough introduction to the project and its current capabilities.

dinsd currently requires Python 3.4 (as of this writing that means Python built from the head of the Python "default" branch in Mercurial). Mostly it will run fine using Python 3.3, and I will officially support whatever the most recent Python release is at the point where other people start wanting to play with it.

Note that there is another project with a similar goal:

http://www.quicksort.co.uk/DeeDoc.html

Dee is a Python 2.7 project, and does not appear to be in current development.