예제 #1
0
        internal void CalculateSync()
        {
            if (SyncEntireLibrary)
            {
                sync_src.ConditionTree = null;
            }
            else if (SyncSource != null)
            {
                var           src            = SyncSource;
                QueryListNode playlists_node = new QueryListNode(Keyword.Or);
                if (src is PlaylistSource)
                {
                    playlists_node.AddChild(UserQueryParser.Parse(String.Format("playlistid:{0}", (src as PlaylistSource).DbId), BansheeQuery.FieldSet));
                }
                else if (src is SmartPlaylistSource)
                {
                    playlists_node.AddChild(UserQueryParser.Parse(String.Format("smartplaylistid:{0}", (src as SmartPlaylistSource).DbId), BansheeQuery.FieldSet));
                }
                sync_src.ConditionTree = playlists_node;
            }

            sync_src.RefreshAndReload();
            to_add.RefreshAndReload();
            to_remove.RefreshAndReload();
        }
예제 #2
0
        private QueryNode BuildQueryTree(QueryFieldSet fields, Operator op, string target, bool force)
        {
            if (fields == null || op == null || String.IsNullOrEmpty(target))
            {
                return(null);
            }

            QueryListNode root = new QueryListNode(Keyword.Or);

            foreach (QueryField field in fields)
            {
                if (force || field.IsDefault)
                {
                    root.AddChild(CreateNode(field, op, target));
                }
            }

            // force the query to build if no default fields in QueryFieldSet
            if (!force && root.ChildCount == 0)
            {
                return(BuildQueryTree(fields, op, target, true));
            }

            return(root.Trim());
        }
예제 #3
0
        private string ParseCondition(string value)
        {
            if (String.IsNullOrEmpty(value))
            {
                return(null);
            }

            // Check for ANDs or ORs and split into conditions as needed
            string [] conditions;
            bool      ands = true;

            if (value.IndexOf(") AND (") != -1)
            {
                ands       = true;
                conditions = System.Text.RegularExpressions.Regex.Split(value, "\\) AND \\(");
            }
            else if (value.IndexOf(") OR (") != -1)
            {
                ands       = false;
                conditions = System.Text.RegularExpressions.Regex.Split(value, "\\) OR \\(");
            }
            else
            {
                conditions = new string [] { value };
            }

            QueryListNode root = new QueryListNode(ands ? Keyword.And : Keyword.Or);

            // Remove leading spaces and parens from the first condition
            conditions[0] = conditions[0].Remove(0, 2);

            // Remove trailing spaces and last paren from the last condition
            string tmp = conditions[conditions.Length - 1];

            tmp = tmp.TrimEnd(new char[] { ' ' });
            tmp = tmp.Substring(0, tmp.Length - 1);
            conditions[conditions.Length - 1] = tmp;

            int count = 0;

            foreach (string condition in conditions)
            {
                // Add a new row for this condition
                string col, v1, v2;
                foreach (QueryOperator op in QueryOperator.Operators)
                {
                    if (op.MatchesCondition(condition, out col, out v1, out v2))
                    {
                        QueryTermNode term             = new QueryTermNode();
                        QueryField    field            = BansheeQuery.FieldSet [col];
                        bool          is_relative_date = false;
                        if (field == null)
                        {
                            if (col.IndexOf("DateAddedStamp") != -1)
                            {
                                field = BansheeQuery.FieldSet ["added"];
                            }
                            else if (col.IndexOf("LastPlayedStamp") != -1)
                            {
                                field = BansheeQuery.FieldSet ["lastplayed"];
                            }

                            // Fix ugly implementation of playlist/smart playlist conditions
                            if (op == QueryOperator.InPlaylist || op == QueryOperator.NotInPlaylist)
                            {
                                field = BansheeQuery.FieldSet ["playlist"];
                            }
                            else if (op == QueryOperator.InSmartPlaylist || op == QueryOperator.NotInSmartPlaylist)
                            {
                                field = BansheeQuery.FieldSet ["smartplaylist"];
                            }

                            if (field == null)
                            {
                                continue;
                            }
                            is_relative_date = true;
                        }

                        term.Field = field;

                        if (op == QueryOperator.Between)
                        {
                            QueryListNode and = new QueryListNode(Keyword.And);
                            QueryTermNode t2  = new QueryTermNode();
                            t2.Field = term.Field;

                            if (is_relative_date)
                            {
                                ParseRelativeDateCondition(term, v1, field, ">=");
                                ParseRelativeDateCondition(t2, v2, field, "<=");
                            }
                            else
                            {
                                term.Value    = QueryValue.CreateFromUserQuery(v1, field);
                                term.Operator = term.Value.OperatorSet ["<="];

                                t2.Value    = QueryValue.CreateFromUserQuery(v2, field);
                                t2.Operator = t2.Value.OperatorSet [">="];
                            }
                            and.AddChild(term);
                            and.AddChild(t2);
                            root.AddChild(and);
                        }
                        else if (is_relative_date)
                        {
                            ParseRelativeDateCondition(term, v1, field, op.NewOp);
                            root.AddChild(term);
                        }
                        else
                        {
                            term.Value    = QueryValue.CreateFromUserQuery(v1, field);
                            term.Operator = term.Value.OperatorSet [op.NewOp];
                            root.AddChild(term);
                        }

                        break;
                    }
                }

                count++;
            }

            QueryNode node = root.Trim();

            if (node != null)
            {
                //Console.WriteLine ("After XML: {0}", node.ToXml (BansheeQuery.FieldSet, true));
                //Console.WriteLine ("After SQL: {0}", node.ToSql (BansheeQuery.FieldSet));
            }

            return(node == null ? String.Empty : node.ToXml(BansheeQuery.FieldSet));
        }