mirror of
https://github.com/ElvishArtisan/rivendell.git
synced 2025-04-09 22:43:11 +02:00
2020-03-18 Fred Gleason <fredg@paravelsystems.com>
* Added a 'FEED_IMAGES' table to the database. * Added 'feed_image_test' in 'tests/'. Signed-off-by: Fred Gleason <fredg@paravelsystems.com>
This commit is contained in:
parent
18e82cfdbe
commit
434c6c8070
1
.gitignore
vendored
1
.gitignore
vendored
@ -110,6 +110,7 @@ tests/dateparse_test
|
|||||||
tests/db_charset_test
|
tests/db_charset_test
|
||||||
tests/delete_test
|
tests/delete_test
|
||||||
tests/download_test
|
tests/download_test
|
||||||
|
tests/feed_image_test
|
||||||
tests/getpids_test
|
tests/getpids_test
|
||||||
tests/log_unlink_test
|
tests/log_unlink_test
|
||||||
tests/mcast_recv_test
|
tests/mcast_recv_test
|
||||||
|
@ -19834,3 +19834,6 @@
|
|||||||
* Fixed a regression in rdairplay(1) that caused two events to be
|
* Fixed a regression in rdairplay(1) that caused two events to be
|
||||||
started by a single spacebar tap if a SoundPanel event had been
|
started by a single spacebar tap if a SoundPanel event had been
|
||||||
played previously.
|
played previously.
|
||||||
|
2020-03-18 Fred Gleason <fredg@paravelsystems.com>
|
||||||
|
* Added a 'FEED_IMAGES' table to the database.
|
||||||
|
* Added 'feed_image_test' in 'tests/'.
|
||||||
|
@ -50,6 +50,7 @@ EXTRA_DIST = audio_cards.txt\
|
|||||||
events.txt\
|
events.txt\
|
||||||
extended_panel_names.txt\
|
extended_panel_names.txt\
|
||||||
extended_panels.txt\
|
extended_panels.txt\
|
||||||
|
feed_images.txt\
|
||||||
feed_perms.txt\
|
feed_perms.txt\
|
||||||
feeds.txt\
|
feeds.txt\
|
||||||
gpio_events.txt\
|
gpio_events.txt\
|
||||||
|
15
docs/tables/feed_images.txt
Normal file
15
docs/tables/feed_images.txt
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
FEED_IMAGES Table Layout for Rivendell
|
||||||
|
|
||||||
|
The FEED_IMAGES table holds binary images used by podcast feeds.
|
||||||
|
|
||||||
|
|
||||||
|
FIELD NAME TYPE REMARKS
|
||||||
|
---------------------------------------------------------------
|
||||||
|
ID int(10) unsigned Primary key, auto increment
|
||||||
|
FEED_ID int(10) unsigned From FEEDS.ID
|
||||||
|
FEED_KEY_NAME varchar(8) From FEEDS.KEY_NAME
|
||||||
|
WIDTH int(11) signed Pixels
|
||||||
|
HEIGHT int(11) signed Pixels
|
||||||
|
DEPTH int(11) signed Bits/pixel
|
||||||
|
DESCRIPTION text
|
||||||
|
DATA mediumblob
|
@ -24,7 +24,7 @@
|
|||||||
/*
|
/*
|
||||||
* Current Database Version
|
* Current Database Version
|
||||||
*/
|
*/
|
||||||
#define RD_VERSION_DATABASE 319
|
#define RD_VERSION_DATABASE 320
|
||||||
|
|
||||||
|
|
||||||
#endif // DBVERSION_H
|
#endif // DBVERSION_H
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
//
|
//
|
||||||
// Escape non-valid characters in a string.
|
// Escape non-valid characters in a string.
|
||||||
//
|
//
|
||||||
// (C) Copyright 2002-2005,2016-2017 Fred Gleason <fredg@paravelsystems.com>
|
// (C) Copyright 2002-2020 Fred Gleason <fredg@paravelsystems.com>
|
||||||
//
|
//
|
||||||
// This program is free software; you can redistribute it and/or modify
|
// This program is free software; you can redistribute it and/or modify
|
||||||
// it under the terms of the GNU General Public License version 2 as
|
// it under the terms of the GNU General Public License version 2 as
|
||||||
@ -113,3 +113,21 @@ QString RDEscapeShellString(QString str)
|
|||||||
{
|
{
|
||||||
return "\""+str.replace("$","\\$")+"\"";
|
return "\""+str.replace("$","\\$")+"\"";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
QString RDEscapeBlob(const QByteArray &data)
|
||||||
|
{
|
||||||
|
return RDEscapeBlob(data.constData(),data.length());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
QString RDEscapeBlob(const char *data,size_t len)
|
||||||
|
{
|
||||||
|
QString ret="x'";
|
||||||
|
|
||||||
|
for(unsigned i=0;i<len;i++) {
|
||||||
|
ret+=QString().sprintf("%02x",0xff&data[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret+"'";
|
||||||
|
}
|
||||||
|
@ -18,17 +18,20 @@
|
|||||||
// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
//
|
//
|
||||||
|
|
||||||
#include <qstring.h>
|
|
||||||
#include <qdatetime.h>
|
|
||||||
|
|
||||||
#ifndef RDESCAPE_STRING_H
|
#ifndef RDESCAPE_STRING_H
|
||||||
#define RDESCAPE_STRING_H
|
#define RDESCAPE_STRING_H
|
||||||
|
|
||||||
|
#include <qbytearray.h>
|
||||||
|
#include <qdatetime.h>
|
||||||
|
#include <qstring.h>
|
||||||
|
|
||||||
QString RDCheckDateTime(const QTime &time, const QString &format);
|
QString RDCheckDateTime(const QTime &time, const QString &format);
|
||||||
QString RDCheckDateTime(const QDateTime &datetime, const QString &format);
|
QString RDCheckDateTime(const QDateTime &datetime, const QString &format);
|
||||||
QString RDCheckDateTime(const QDate &date, const QString &format);
|
QString RDCheckDateTime(const QDate &date, const QString &format);
|
||||||
QString RDEscapeString(const QString &str);
|
QString RDEscapeString(const QString &str);
|
||||||
QString RDEscapeShellString(QString str);
|
QString RDEscapeShellString(QString str);
|
||||||
|
QString RDEscapeBlob(const QByteArray &data);
|
||||||
|
QString RDEscapeBlob(const char *data,size_t len);
|
||||||
|
|
||||||
|
|
||||||
#endif // RDESCAPE_STRING_H
|
#endif // RDESCAPE_STRING_H
|
||||||
|
@ -36,6 +36,7 @@ noinst_PROGRAMS = audio_convert_test\
|
|||||||
db_charset_test\
|
db_charset_test\
|
||||||
delete_test\
|
delete_test\
|
||||||
download_test\
|
download_test\
|
||||||
|
feed_image_test\
|
||||||
getpids_test\
|
getpids_test\
|
||||||
log_unlink_test\
|
log_unlink_test\
|
||||||
mcast_recv_test\
|
mcast_recv_test\
|
||||||
@ -81,6 +82,9 @@ delete_test_LDADD = @LIB_RDLIBS@ @LIBVORBIS@ @QT4_LIBS@ @MUSICBRAINZ_LIBS@ -lQt3
|
|||||||
dist_download_test_SOURCES = download_test.cpp download_test.h
|
dist_download_test_SOURCES = download_test.cpp download_test.h
|
||||||
download_test_LDADD = @LIB_RDLIBS@ @LIBVORBIS@ @QT4_LIBS@ @MUSICBRAINZ_LIBS@ -lQt3Support
|
download_test_LDADD = @LIB_RDLIBS@ @LIBVORBIS@ @QT4_LIBS@ @MUSICBRAINZ_LIBS@ -lQt3Support
|
||||||
|
|
||||||
|
dist_feed_image_test_SOURCES = feed_image_test.cpp feed_image_test.h
|
||||||
|
feed_image_test_LDADD = @LIB_RDLIBS@ @LIBVORBIS@ @QT4_LIBS@ @MUSICBRAINZ_LIBS@ -lQt3Support
|
||||||
|
|
||||||
dist_getpids_test_SOURCES = getpids_test.cpp getpids_test.h
|
dist_getpids_test_SOURCES = getpids_test.cpp getpids_test.h
|
||||||
getpids_test_LDADD = @LIB_RDLIBS@ @LIBVORBIS@ @QT4_LIBS@ @MUSICBRAINZ_LIBS@ -lQt3Support
|
getpids_test_LDADD = @LIB_RDLIBS@ @LIBVORBIS@ @QT4_LIBS@ @MUSICBRAINZ_LIBS@ -lQt3Support
|
||||||
|
|
||||||
|
290
tests/feed_image_test.cpp
Normal file
290
tests/feed_image_test.cpp
Normal file
@ -0,0 +1,290 @@
|
|||||||
|
// feed_image_test.cpp
|
||||||
|
//
|
||||||
|
// Test Rivendell image storage
|
||||||
|
//
|
||||||
|
// (C) Copyright 2010-2020 Fred Gleason <fredg@paravelsystems.com>
|
||||||
|
//
|
||||||
|
// This program is free software; you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License version 2 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, write to the Free Software
|
||||||
|
// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
#include <qapplication.h>
|
||||||
|
#include <qfile.h>
|
||||||
|
#include <qimage.h>
|
||||||
|
|
||||||
|
#include <rdapplication.h>
|
||||||
|
#include <rdescape_string.h>
|
||||||
|
|
||||||
|
#include "feed_image_test.h"
|
||||||
|
|
||||||
|
MainObject::MainObject(QObject *parent)
|
||||||
|
:QObject(parent)
|
||||||
|
{
|
||||||
|
QString err_msg;
|
||||||
|
QString key_name;
|
||||||
|
bool ok=false;
|
||||||
|
MainObject::Command command=MainObject::None;
|
||||||
|
test_image_id=-1;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Open the Database
|
||||||
|
//
|
||||||
|
rda=new RDApplication("feed_image_test","feed_image_test",FEED_IMAGE_TEST_USAGE,this);
|
||||||
|
if(!rda->open(&err_msg)) {
|
||||||
|
fprintf(stderr,"feed_image_test: %s\n",(const char *)err_msg);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// Read Command Options
|
||||||
|
//
|
||||||
|
for(unsigned i=0;i<rda->cmdSwitch()->keys();i++) {
|
||||||
|
if(rda->cmdSwitch()->key(i)=="--feed") {
|
||||||
|
key_name=rda->cmdSwitch()->value(i);
|
||||||
|
rda->cmdSwitch()->setProcessed(i,true);
|
||||||
|
}
|
||||||
|
if(rda->cmdSwitch()->key(i)=="--filename") {
|
||||||
|
test_filename=rda->cmdSwitch()->value(i);
|
||||||
|
rda->cmdSwitch()->setProcessed(i,true);
|
||||||
|
}
|
||||||
|
if(rda->cmdSwitch()->key(i)=="--description") {
|
||||||
|
test_description=rda->cmdSwitch()->value(i);
|
||||||
|
rda->cmdSwitch()->setProcessed(i,true);
|
||||||
|
}
|
||||||
|
if(rda->cmdSwitch()->key(i)=="--image-id") {
|
||||||
|
test_image_id=rda->cmdSwitch()->value(i).toInt(&ok);
|
||||||
|
if((!ok)||(test_image_id<0)) {
|
||||||
|
fprintf(stderr,"feed_image_test: invalid --image-id\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
rda->cmdSwitch()->setProcessed(i,true);
|
||||||
|
}
|
||||||
|
if(rda->cmdSwitch()->key(i)=="--list") {
|
||||||
|
if(command!=MainObject::None) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"feed_image_test: --list, --pop and --push are mutually exclusive\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
command=MainObject::List;
|
||||||
|
rda->cmdSwitch()->setProcessed(i,true);
|
||||||
|
}
|
||||||
|
if(rda->cmdSwitch()->key(i)=="--pop") {
|
||||||
|
if(command!=MainObject::None) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"feed_image_test: --list, --pop and --push are mutually exclusive\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
command=MainObject::Pop;
|
||||||
|
rda->cmdSwitch()->setProcessed(i,true);
|
||||||
|
}
|
||||||
|
if(rda->cmdSwitch()->key(i)=="--push") {
|
||||||
|
if(command!=MainObject::None) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"feed_image_test: --list, --pop and --push are mutually exclusive\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
command=MainObject::Push;
|
||||||
|
rda->cmdSwitch()->setProcessed(i,true);
|
||||||
|
}
|
||||||
|
if(!rda->cmdSwitch()->processed(i)) {
|
||||||
|
fprintf(stderr,"feed_image_test: unknown command option \"%s\"\n",
|
||||||
|
(const char *)rda->cmdSwitch()->key(i));
|
||||||
|
exit(2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// Sanity Checks
|
||||||
|
//
|
||||||
|
if(command==MainObject::None) {
|
||||||
|
fprintf(stderr,"feed_image_test: you must specify --list, --pop or --push\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Get the feed data
|
||||||
|
//
|
||||||
|
|
||||||
|
//
|
||||||
|
// Dispatch
|
||||||
|
//
|
||||||
|
switch(command) {
|
||||||
|
case MainObject::List:
|
||||||
|
if(key_name.isEmpty()) {
|
||||||
|
fprintf(stderr,"feed_image_test: you must specify --feed=<key-name>\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
test_feed=new RDFeed(key_name,rda->config(),this);
|
||||||
|
if(!test_feed->exists()) {
|
||||||
|
fprintf(stderr,"feed_image_test: no such feed\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
RunList();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case MainObject::Pop:
|
||||||
|
if(test_image_id<0) {
|
||||||
|
fprintf(stderr,"feed_image_test: you must specify --image-id\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if(test_filename.isEmpty()) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"feed_image_test: you must specify --filename=<file-name>\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
RunPop();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case MainObject::Push:
|
||||||
|
if(key_name.isEmpty()) {
|
||||||
|
fprintf(stderr,"feed_image_test: you must specify --feed=<key-name>\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
test_feed=new RDFeed(key_name,rda->config(),this);
|
||||||
|
if(!test_feed->exists()) {
|
||||||
|
fprintf(stderr,"feed_image_test: no such feed\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if(test_filename.isEmpty()) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"feed_image_test: you must specify --filename=<file-name>\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if(test_description.isEmpty()) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"feed_image_test: you must specify --description=<img-desc>\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
RunPush();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case MainObject::None:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MainObject::RunList()
|
||||||
|
{
|
||||||
|
QString sql;
|
||||||
|
RDSqlQuery *q=NULL;
|
||||||
|
|
||||||
|
sql=QString("select ")+
|
||||||
|
"ID,"+ // 00
|
||||||
|
"WIDTH,"+ // 01
|
||||||
|
"HEIGHT,"+ // 02
|
||||||
|
"DEPTH,"+ // 03
|
||||||
|
"DESCRIPTION "+ // 04
|
||||||
|
"from FEED_IMAGES where "+
|
||||||
|
"FEED_KEY_NAME=\""+RDEscapeString(test_feed->keyName())+"\"";
|
||||||
|
q=new RDSqlQuery(sql);
|
||||||
|
while(q->next()) {
|
||||||
|
printf("ID: %u\n",q->value(0).toUInt());
|
||||||
|
printf(" Description: %s\n",q->value(4).toString().toUtf8().constData());
|
||||||
|
printf(" Dimensions: %dx%dx%d\n",q->value(1).toInt(),q->value(2).toInt(),
|
||||||
|
q->value(3).toInt());
|
||||||
|
printf("\n");
|
||||||
|
}
|
||||||
|
delete q;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MainObject::RunPush()
|
||||||
|
{
|
||||||
|
QString sql;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Load the image
|
||||||
|
//
|
||||||
|
QFile file(test_filename);
|
||||||
|
if(!file.open(QIODevice::ReadOnly)) {
|
||||||
|
fprintf(stderr,"feed_image_test: unable to open image file [%s]\n",
|
||||||
|
strerror(errno));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
QByteArray data=file.readAll();
|
||||||
|
file.close();
|
||||||
|
|
||||||
|
//
|
||||||
|
// Validate the image
|
||||||
|
//
|
||||||
|
QImage *img=new QImage();
|
||||||
|
if(!img->loadFromData(data)) {
|
||||||
|
fprintf(stderr,"feed_image_test: invalid image file\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
printf("Image is %dx%dx%d\n",img->width(),img->height(),img->depth());
|
||||||
|
|
||||||
|
//
|
||||||
|
// Write it to the DB
|
||||||
|
//
|
||||||
|
sql=QString("insert into FEED_IMAGES set ")+
|
||||||
|
QString().sprintf("FEED_ID=%u,",test_feed->id())+
|
||||||
|
"FEED_KEY_NAME=\""+RDEscapeString(test_feed->keyName())+"\","+
|
||||||
|
QString().sprintf("WIDTH=%d,",img->width())+
|
||||||
|
QString().sprintf("HEIGHT=%d,",img->height())+
|
||||||
|
QString().sprintf("DEPTH=%d,",img->depth())+
|
||||||
|
"DESCRIPTION=\""+RDEscapeString(test_description)+"\","+
|
||||||
|
"DATA="+RDEscapeBlob(data);
|
||||||
|
RDSqlQuery::apply(sql);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MainObject::RunPop()
|
||||||
|
{
|
||||||
|
QString sql;
|
||||||
|
RDSqlQuery *q=NULL;
|
||||||
|
QByteArray data;
|
||||||
|
FILE *f=NULL;
|
||||||
|
|
||||||
|
sql=QString("select DATA from FEED_IMAGES where ")+
|
||||||
|
QString().sprintf("ID=%u",test_image_id);
|
||||||
|
q=new RDSqlQuery(sql);
|
||||||
|
if(q->first()) {
|
||||||
|
if((f=fopen(test_filename.toUtf8(),"w"))==NULL) {
|
||||||
|
fprintf(stderr,"feed_image_test: unable to open \"%s\" [%s]\n",
|
||||||
|
test_filename.toUtf8().constData(),strerror(errno));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
data=q->value(0).toByteArray();
|
||||||
|
if(fwrite(data.constData(),1,data.size(),f)<0) {
|
||||||
|
fprintf(stderr,"feed_image_test: unable to write to \"%s\" [%s]\n",
|
||||||
|
test_filename.toUtf8().constData(),strerror(errno));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
fprintf(stderr,"feed_image_test: no such image\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
delete q;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main(int argc,char *argv[])
|
||||||
|
{
|
||||||
|
QApplication a(argc,argv,false);
|
||||||
|
new MainObject();
|
||||||
|
return a.exec();
|
||||||
|
}
|
48
tests/feed_image_test.h
Normal file
48
tests/feed_image_test.h
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
// feed_image_test.h
|
||||||
|
//
|
||||||
|
// Test Rivendell image storage.
|
||||||
|
//
|
||||||
|
// (C) Copyright 2010-2020 Fred Gleason <fredg@paravelsystems.com>
|
||||||
|
//
|
||||||
|
// This program is free software; you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License version 2 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, write to the Free Software
|
||||||
|
// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef FEED_IMAGE_TEST_H
|
||||||
|
#define FEED_IMAGE_TEST_H
|
||||||
|
|
||||||
|
#include <qobject.h>
|
||||||
|
|
||||||
|
#include <rdfeed.h>
|
||||||
|
|
||||||
|
#define FEED_IMAGE_TEST_USAGE "[options]\n\nTest the Rivendell binary image routines\n\nOptions are:\n--push | --pop | --list\n\n--description=<str>\n\n--name=<str>\n\n--feed=<key-name>\n\n--image-id=<id>\n\n"
|
||||||
|
|
||||||
|
class MainObject : public QObject
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
enum Command {None=0,List=1,Push=2,Pop=3};
|
||||||
|
MainObject(QObject *parent=0);
|
||||||
|
|
||||||
|
private:
|
||||||
|
void RunList();
|
||||||
|
void RunPush();
|
||||||
|
void RunPop();
|
||||||
|
QString test_filename;
|
||||||
|
QString test_description;
|
||||||
|
QString test_name;
|
||||||
|
RDFeed *test_feed;
|
||||||
|
int test_image_id;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // FEED_IMAGE_TEST_H
|
@ -41,6 +41,15 @@ bool MainObject::RevertSchema(int cur_schema,int set_schema,QString *err_msg)
|
|||||||
// NEW SCHEMA REVERSIONS GO HERE...
|
// NEW SCHEMA REVERSIONS GO HERE...
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Revert 320
|
||||||
|
//
|
||||||
|
if((cur_schema==320)&&(set_schema<cur_schema)) {
|
||||||
|
DropTable("FEED_IMAGES");
|
||||||
|
|
||||||
|
WriteSchemaVersion(--cur_schema);
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// Revert 319
|
// Revert 319
|
||||||
//
|
//
|
||||||
|
@ -160,7 +160,7 @@ void MainObject::InitializeSchemaMap() {
|
|||||||
global_version_map["3.1"]=310;
|
global_version_map["3.1"]=310;
|
||||||
global_version_map["3.2"]=311;
|
global_version_map["3.2"]=311;
|
||||||
global_version_map["3.3"]=314;
|
global_version_map["3.3"]=314;
|
||||||
global_version_map["3.4"]=319;
|
global_version_map["3.4"]=320;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -10011,6 +10011,26 @@ bool MainObject::UpdateSchema(int cur_schema,int set_schema,QString *err_msg)
|
|||||||
WriteSchemaVersion(++cur_schema);
|
WriteSchemaVersion(++cur_schema);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if((cur_schema<320)&&(set_schema>cur_schema)) {
|
||||||
|
sql=QString("create table FEED_IMAGES (")+
|
||||||
|
"ID int unsigned primary key,"+
|
||||||
|
"FEED_ID int unsigned not null,"+
|
||||||
|
"FEED_KEY_NAME varchar(8) not null,"+
|
||||||
|
"WIDTH int not null,"+\
|
||||||
|
"HEIGHT int not null,"+
|
||||||
|
"DEPTH int not null,"+
|
||||||
|
"DESCRIPTION text,"+
|
||||||
|
"DATA mediumblob not null,"+
|
||||||
|
"index FEED_ID_IDX (FEED_ID),"+
|
||||||
|
"index FEED_KEY_NAME_IDX (FEED_KEY_NAME))";
|
||||||
|
if(!RDSqlQuery::apply(sql,err_msg)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
WriteSchemaVersion(++cur_schema);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// NEW SCHEMA UPDATES GO HERE...
|
// NEW SCHEMA UPDATES GO HERE...
|
||||||
|
Loading…
x
Reference in New Issue
Block a user