summaryrefslogtreecommitdiff
path: root/portato/db/__init__.py
blob: 21d8f80c02725f22e838eb16c299a2d729f6a653 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# -*- coding: utf-8 -*-
#
# File: portato/db/__init__.py
# This file is part of the Portato-Project, a graphical portage-frontend.
#
# Copyright (C) 2006-2010 René 'Necoro' Neumann
# This is free software.  You may redistribute copies of it under the terms of
# the GNU General Public License version 2.
# There is NO WARRANTY, to the extent permitted by law.
#
# Written by René 'Necoro' Neumann <necoro@necoro.net>

from __future__ import absolute_import

from . import database as db
from .exceptions import UnknownDatabaseTypeError, DatabaseInstantiationError
from ..session import Session, SectionDict
from ..helper import debug, warning, error, info

types = (
        ("eixsql", _("eix + SQLite"), _("Similar to SQLite, but now uses the eix database to get the package information.\nThis should be much faster on startup, but requires that your eix database is always up-to-date.\nAdditionally, this is the only database allowing searching in descriptions.")),
        ("sql", _("SQLite"), _("Uses an SQLite-database to store package information.\nMay take longer to generate at the first time, but has advantages if portato is re-started with an unchanged portage tree. Additionally it allows to use fast SQL expressions for fetching the data.")),
        ("dict", _("Hashmap"), _("Uses an in-memory hashmap to store package information.\nHas been used since at least version 0.3.3, but all information has to be regenerated on each startup."))
        )

class Database(db.Database):
    DEFAULT = "dict"

    def __new__ (cls, type = None):
        if not '_the_instance' in cls.__dict__:
            dbcls = cls._generate(type)
            cls._the_instance = dbcls(cls._get_session())
        elif type is not None:
            raise DatabaseInstantiationError("Database instantiation called with 'type' argument multiple times.")
        return cls._the_instance
    
    @classmethod
    def _generate(cls, type):

        if type is None:
            warning("No database type specified! Falling back to default.")
            type = cls.DEFAULT
        
        cls.DB_TYPE = type
        msg = _("Using database type '%s'")

        if type == "sql":
            info(msg, "SQLDatabase")
            try:
                from .sql import SQLDatabase
            except ImportError:
                warning(_("Cannot load %s."), "SQLDatabase")
                return cls._generate("dict")
            else:
                return SQLDatabase

        elif type == "dict":
            info(msg, "HashDatabase")
            from .hash import HashDatabase
            return HashDatabase
        
        elif type == "eixsql":
            info(msg,"EixSQLDatabase")
            try:
                from .eix_sql import EixSQLDatabase
            except ImportError:
                warning(_("Cannot load %s."), "EixSQLDatabase.")
                return cls._generate("sql")
            else:
                return EixSQLDatabase

        else:
            error(_("Unknown database type: %s"), type)
            raise UnknownDatabaseTypeError, type

    @classmethod
    def _get_session(cls):
        return SectionDict(Session("db.cfg", name = "DB"), cls.DB_TYPE)