// rdcart_search_text.cpp // // Generates a standardized SQL 'INNER JOIN' and 'WHERE' clause for // filtering Rivendell carts. // // (C) Copyright 2002-2004,2016 Fred Gleason // // 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 #include #include QString RDBaseSearchText(QString filter,bool incl_cuts) { QString edit_filter=filter; QString ret=""; QString str=""; int pos=0; char find; edit_filter=edit_filter.stripWhiteSpace(); if(edit_filter.isEmpty()) { ret=QString(" ((CART.TITLE like \"%%\")||")+ "(CART.ARTIST like \"%%\")||"+ "(CART.CLIENT like \"%%\")||"+ "(CART.AGENCY like \"%%\")||"+ "(CART.ALBUM like \"%%\")||"+ "(CART.LABEL like \"%%\")||"+ "(CART.NUMBER like \"%%\")||"+ "(CART.PUBLISHER like \"%%\")||"+ "(CART.COMPOSER like \"%%\")||"+ "(CART.CONDUCTOR like \"%%\")||"+ "(CART.SONG_ID like \"%%\")||"+ "(CART.USER_DEFINED like \"%%\")"; if(incl_cuts) { ret+=QString("||(CUTS.ISCI like \"%%\")")+ "||(CUTS.ISRC like \"%%\")"+ "||(CUTS.DESCRIPTION like \"%%\")"+ "||(CUTS.OUTCUE like \"%%\")"; } ret+=")"; } else { while(!edit_filter.isEmpty()) { if(edit_filter.startsWith("\"") && edit_filter.length()>1) { edit_filter=edit_filter.remove(0,1); find='\"'; } else { find=' '; } pos=edit_filter.find(find); if(pos>=0) { str=edit_filter.left(pos); edit_filter=edit_filter.remove(0,pos); if(find=='\"') { edit_filter=edit_filter.remove(0,1); } edit_filter=edit_filter.stripWhiteSpace(); } else { str=edit_filter; edit_filter=edit_filter.remove(0,edit_filter.length()); } if(!ret.isEmpty()) { ret=ret+" AND "; } QString search=RDEscapeString(str); ret=ret+QString(" ((CART.TITLE like \"%")+search+"%\")||"+ "(CART.ARTIST like \"%"+search+"%\")||"+ "(CART.CLIENT like \"%"+search+"%\")||"+ "(CART.AGENCY like \"%"+search+"%\")||"+ "(CART.ALBUM like \"%"+search+"%\")||"+ "(CART.LABEL like \"%"+search+"%\")||"+ "(CART.NUMBER like \"%"+search+"%\")||"+ "(CART.PUBLISHER like \"%"+search+"%\")||"+ "(CART.COMPOSER like \"%"+search+"%\")||"+ "(CART.CONDUCTOR like \"%"+search+"%\")||"+ "(CART.SONG_ID like \"%"+search+"%\")||"+ "(CART.USER_DEFINED like \"%"+search+"%\")"; if(incl_cuts) { ret+=QString("||(CUTS.ISCI like \"%")+search+"%\")"+ "||(CUTS.ISRC like \"%"+search+"%\")"+ "||(CUTS.DESCRIPTION like \"%"+search+"%\")"+ "||(CUTS.OUTCUE like \"%"+search+"%\")"; } ret+=") "; } } return ret; } QString RDSchedSearchText(const QString &schedcode) { QString ret=""; if(!schedcode.isEmpty()) { ret+=QString(" inner join CART_SCHED_CODES on CART.NUMBER=CART_SCHED_CODES.CART_NUMBER and CART_SCHED_CODES.SCHED_CODE=\"")+RDEscapeString(schedcode)+"\" "; } return ret; } QString RDSchedSearchText(const QStringList &schedcodes) { QString ret=""; for(int i=0;inext()) { search+=QString("(CART.GROUP_NAME=\"")+ RDEscapeString(q->value(0).toString())+"\")||"; } delete q; search=search.left(search.length()-2)+QString(")"); search+=QString("&&")+RDBaseSearchText(filter,incl_cuts); return search; } QString RDAllCartSearchText(const QString &filter,const QStringList &schedcodes, const QString &user,bool incl_cuts) { QString sql; RDSqlQuery *q; QString search=""; search+=RDSchedSearchText(schedcodes); search+=" where ("; sql=QString("select GROUP_NAME from USER_PERMS where ")+ "USER_NAME=\""+RDEscapeString(user)+"\""; q=new RDSqlQuery(sql); while(q->next()) { search+=QString("(CART.GROUP_NAME=\"")+ RDEscapeString(q->value(0).toString())+"\")||"; } delete q; search=search.left(search.length()-2)+QString(")"); search+=QString("&&")+RDBaseSearchText(filter,incl_cuts); return search; }