setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {
	/* If there is an error an exception is thrown */
	echo 'Connection failed
';
	echo 'Error number: ' . $e->getCode() . '
';
	echo 'Error message: ' . $e->getMessage() . '
';
	die();
}
function get_dir_info($dir) {
	global $pdo;
	$sql = 'SELECT * FROM dirs WHERE path = :dir';
	$values = array(
		':dir' => $dir
	);
	try {
		$res = $pdo->prepare($sql);
		$res->execute($values);
	} catch (PDOException $e) {
		echo 'Query error: ' . $e->getMessage();
		die();
	}
	if(!($row = $res->fetch(PDO::FETCH_ASSOC))) {
		return null;
	}
	return $row;
}
function get_dir_list() {
	global $pdo;
	$dir = [];
	$query = 'SELECT * FROM dirs ORDER BY date DESC';
	try {
		$res = $pdo->query($query);
	} catch (PDOException $e) {
		echo 'Query error: ' . $e->getMessage();
		die();
	}
	while ($row = $res->fetch(PDO::FETCH_ASSOC)) {
		$dir[] = $row;
	}
	return $dir;
}
function get_dir_count($dir) {
        global $pdo;
        $sql = 'SELECT id FROM dirs WHERE path = :dir';
        $values = array(
                ':dir' => $dir
        );
        try {
                $res = $pdo->prepare($sql);
                $res->execute($values);
        } catch (PDOException $e) {
                echo 'Query error: ' . $e->getMessage();
                die();
        }
        if(!($row = $res->fetch(PDO::FETCH_ASSOC))) {
                return 0;
        }
	$dirid = $row['id'];
	$sql = 'SELECT count(*) AS count FROM images WHERE dir = :dirid';
	$values = array(
		':dirid' => $dirid
	);
        try {
                $res = $pdo->prepare($sql);
                $res->execute($values);
        } catch (PDOException $e) {
                echo 'Query error: ' . $e->getMessage();
                die();
        }
        if(!($row = $res->fetch(PDO::FETCH_ASSOC))) {
                return 0;
        }
        return $row['count'];
}
function update_dir_count($dirpath, $count) {
        global $pdo;
        $sql = 'UPDATE dirs SET count = :count WHERE path = :path';
        $values = array(
                ':path' => $dirpath,
                ':count' => $count,
        );
        try {
                $res = $pdo->prepare($sql);
                return $res->execute($values);
        } catch (PDOException $e) {
                echo 'Query error: ' . $e->getMessage();
                die();
        }
}
function get_dir_images($dir) {
	global $pdo;
	$images = [];
	$sql = 'SELECT images.id, images.name, images.comment, images.views, images.likes, images.tags, images.path, dirs.name AS dir_name, dirs.comment AS dir_comment, dirs.views AS dir_views, dirs.likes AS dir_likes, dirs.tags AS dir_tags, dirs.path AS dir_path FROM images INNER JOIN dirs ON dirs.id=images.dir WHERE dirs.path = :path ORDER BY images.date ASC';
	$values = array(
		':path' => $dir
	);
	try {
		$res = $pdo->prepare($sql);
		$res->execute($values);
	} catch (PDOException $e) {
		echo 'Query error: ' . $e->getMessage();
		die();
	}
	while ($row = $res->fetch(PDO::FETCH_ASSOC)) {
		$images[] = $row;
		$dirname = $row['dir_name']; // probably should do this only once
	/*	echo '
'; print_r($row); echo ''; echo '