blob: 8e7d0d27e735599b99827f29fa28c38a4b082c80 (
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
|
/***************************************************************************
* Copyright (C) 2003 by *
* Jason Kivlighn (jkivlighn@gmail.com) *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
***************************************************************************/
#ifndef MMFIMPORTER_H
#define MMFIMPORTER_H
#include <tqstring.h>
#include "baseimporter.h"
#include "datablocks/ingredientlist.h"
#include "datablocks/elementlist.h"
/** Class to import Meal-Master's MMF (Meal-Master Format) file format.
* @author Jason Kivlighn
*/
class MMFImporter : public BaseImporter
{
public:
MMFImporter();
virtual ~MMFImporter();
private:
enum FormatVersion { FromDatabase, VersionMMMMM, VersionBB, VersionNormal };
virtual void parseFile( const TQString &filename );
void importMMF( TQTextStream &stream );
/** Parses the line and save it if the line is a valid ingredient and return true.
* Returns false if not an ingredient.
*/
bool loadIngredientLine( const TQString &, IngredientList &, bool &is_sub );
/** Parses the line and save it if the line is a valid ingredient header and return true.
* Returns false if not an ingredient header.
*/
bool loadIngredientHeader( const TQString & );
void resetVars();
void putDataInRecipe();
int m_servings;
TQString m_instructions;
TQString m_title;
ElementList m_authors;
ElementList m_categories;
IngredientList m_left_col_ing;
IngredientList m_right_col_ing;
IngredientList m_all_ing;
FormatVersion version;
TQString current_header;
};
#endif //MMFIMPORTER_H
|