// -*- Mode: C++; indent-tabs-mode: nil; tab-width: 2 -*-
/*
* Copyright (C) 2011 Canonical Ltd
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*
* Authored by: Neil Jagdish Patel
*/
#ifndef UNITY_RESULT_H
#define UNITY_RESULT_H
#include
#include "ModelRowAdaptor.h"
namespace unity
{
namespace dash
{
/* This class represents a DeeModelIter for a ResultsModel
* It's slightly chunky, but that is because it's optimized to be stack-allocated
* as it is not expected to be kept by the views, rather views can easily attach
* a "renderer" to the iter, so when the changed or removed signals are called,
* the view can easily find which widget/view belongs to this iter.
*/
class Result : public RowAdaptorBase
{
public:
Result(DeeModel* model, DeeModelIter* iter, DeeModelTag* tag);
Result(Result const& other);
Result& operator=(Result const& other);
nux::ROProperty uri;
nux::ROProperty icon_hint;
nux::ROProperty category_index;
nux::ROProperty mimetype;
nux::ROProperty name;
nux::ROProperty comment;
nux::ROProperty dnd_uri;
private:
void SetupGetters();
};
}
}
#endif