"http://blogsearch.google.com/blogsearch?client=news&um=1&hl=en&scoring=d&q=SEARCHTERM&ie=utf-8", "google_blogsearch" => "http://blogsearch.google.com/blogsearch_feeds?client=news&um=1&hl=en&scoring=d&q=SEARCHTERM&ie=utf-8&num=NUMRESULTS&output=rss", "twitter_search" => "http://search.twitter.com/search.atom?q=SEARCHTERM&rpp=NUMRESULTS" ); /** * constructor */ function SMIRC($page_title, $title_separators, $required_keyword, $data_sources, $header_text, $animation=false){ $this->page_title = $page_title; $this->title_separators = $title_separators; $this->required_keyword = $required_keyword; $this->data_sources = $data_sources; if($header_text == ""){ $this->header_text = $this->default_header_text; } else { $this->header_text = $header_text; } $this->animation = $animation; } /** * main work method. create url, get data, parse, prep and return xhtml */ function getContent(){ //don't bother doing anything if we don't have any data sources if(!is_array($this->data_sources)){ return false; } //if we have delimiter characters, use them to split up the title $searchterm = $this->_getSearchTerm(); //start assembling data foreach($this->data_sources as $source_array){ //prep url $data_source = str_replace("SEARCHTERM", $searchterm, $this->search_urls[$source_array[0]]); $data_source = str_replace("NUMRESULTS", $source_array[1], $data_source); //get data, put into array $rss_data_array[$source_array[0]]['results'] = $this->_getResults($data_source, split("\n", $source_array[2])); $rss_data_array[$source_array[0]]['header'] = $source_array[3]; } //create and return xhtml for all sources $xhtml = $this->_createXHTML($rss_data_array, $this->header_text); return $xhtml; } /** * create and return all xhtml */ function _createXHTML($rss_array, $header_text){ foreach($rss_array as $data_source => $results_and_header){ //run function to get xhtml from rss object -- name of function depends on data source. $lists_xhtml .= $this->$data_source($results_and_header['results'], $results_and_header['header']); } if($lists_xhtml == ""){ //no results = no xhtml return false; } else { $all_xhtml = '
'; $all_xhtml .= ''; $all_xhtml .= '"; $all_xhtml .= '
'; return $all_xhtml; } } /** * GOOGLE BLOGSEARCH: iterate through rss object and create standards-compliant xhtml for the resultset, while ignoring items in exclude list */ function google_blogsearch($rss_items, $result_header){ $list_xhtml = ""; if(count($rss_items) >= 1){ $list_xhtml = "
  • $result_header
  • "; foreach($rss_items as $item){ $fixed_item = $this->_parseItem($item); $list_xhtml .= '
  • '.$fixed_item['title'].'
    by '.$fixed_item['dc']['creator'].'
    '.strip_tags($fixed_item['summary']).'
  • '; } } return $list_xhtml; } /** * TWITTER SEARCH: iterate through rss object and create standards-compliant xhtml for the resultset * search.twitter.com doesn't seem to have results limits, so we'll have to do that manually. */ function twitter_search($rss_items, $result_header){ $list_xhtml = ""; if(count($rss_items) >= 1){ $list_xhtml = "
  • $result_header
  • "; foreach($rss_items as $item){ $fixed_item = $this->_parseItem($item); $list_xhtml .= '
  • '.$fixed_item['atom_content'].' on '.date(get_option('date_format'), strtotime($fixed_item['published'])).' by '.$fixed_item['author_name'].'
  • '; } } return $list_xhtml; } /** * use title separators (if any) to prepare search term(s) */ function _getSearchTerm(){ if(is_array($this->title_separators)){ //make this easy -- replace all matches to items in separators array with a common character $title = $this->page_title; foreach($this->title_separators as $delimiter){ $title = str_replace($delimiter, "###", $title); } //split by this common character $arr = split("###", $title); //iterate, trim, add to array foreach($arr as $phrase){ $searchterms[] = trim($phrase); } $searchterms[] = $this->required_keyword; } else { //no separators. search terms are title and required keyword if any $searchterms[] = $this->page_title; $searchterms[] = $this->required_keyword; } //iterate through searchterms and add quotation marks / urlencode as needed $str = ""; foreach($searchterms as $term){ $str .= '+"' . urlencode($term) . '"'; } return $str; } /** * using the exclude list (if set) and MagpieRSS, return an array of data sources and results */ function _getResults($data_source, $exclude_list){ $rss = fetch_rss($data_source); //set total results $this->_setTotalResults($rss); $results = $rss->items; //is there an exclude list? if(is_array($exclude_list)){ //yes. iterate and remove foreach($exclude_list as $exclude_me){ $matches = $this->array_search_recursive($exclude_me, $results); unset($results[$matches[0]]); } } return $results; } /** * unfortunately-ghetto way to remove google's BOLDING of matching wordds */ function _parseItem($arr){ $newarr; if(!is_array($arr)){ return $arr; } foreach($arr as $key => $value){ $newval = str_replace("", "", $value); $newval = str_replace("", "", $newval); $newarr[$key] = $newval; } return $newarr; } /** * recursively search a multidimensional array */ function array_search_recursive($needle, $haystack, $path=array()){ foreach($haystack as $id => $val){ $path2 = $path; $path2[] = $id; if(eregi($needle, $val)){ return $path2; } else if(is_array($val)){ if($ret = $this->array_search_recursive($needle, $val, $path2)){ return $ret; } } return false; } } /** * add to total results count */ function _setTotalResults($rss){ if($rss->channel['opensearch']['totalresults']){ $this->total_results = $this->total_results + $rss->channel['opensearch']['totalresults']; } } /** * create header text / link */ function _getHeaderXHTML(){ //create link $link = str_replace("SEARCHTERM", $this->_getSearchTerm(), $this->search_urls['google_blogsearch_norss']); return "" . number_format($this->total_results) . " " . $this->header_text . ""; } } ?> 2009 September 18
    VIP Channel
    Täglich frische VIP News

    Search Our Site

    Recent Posts

    Meta

    :: Archive for September 18th, 2009

     

    September 18th, 2009 | in VIP News | Leave a comment |

    Keine Angst, bei dem Ex handelt es sich nicht um Blake Fielder-Civil, sondern den Musiker Tyler James, mit dem sie 2003 zusammen war. Die Grundlage zur gemeinsamen Feier-Nacht schufen sie beim Italiener, bevor sie in einen Jazz-Club gingen. Dort griff Amy spontan selbst zur Gitarre und spielte ein paar Songs. Und schon am Dienstag zeigte sich Amy von ihrer guten Seite. Sie sang fünf Songs bei der Wohltätigkeitsveranstaltung „Rays of Sunshine“. „Rays of Sunshine“ erfüllt todkranken Kindern deren Wünsche. Ein Zuschauer dazu: „Keiner von uns konnte es glauben. Man liest immer negative Sachen über sie und ihr wildes Verhalten, aber sie hätte nicht netter sein können. Ihr Auftritt hat dem Abend wirklich das I-Tüpfelchen aufgesetzt.“ Wir freuen uns dass es der Sängerin gut geht, und hoffen dass dieses Hoch noch lange anhält.



    September 18th, 2009 | in VIP News | Leave a comment |

    Das freut das Indie-Herz: Pavement sind zurück!
    Knapp zehn Jahre lang war die Band Pavement getrennt. Nun kündigten Steven Malkmus & Co ihre Reunion an. Nächstes Jahr wird die Band für einige Konzerte gemeinsam auf der Bühne stehen. Ob es ein weiteres gemeinsames Album geben wird ist unklar.

    No tags for this post.

    September 18th, 2009 | in VIP News | Leave a comment |

    Ja, er ist glücklich mit seiner Freundin Ayda. Und dass er sie heiraten und eine Familie gründen möchte hatten wir auch schon berichtet. Nun möchte der Sänger nach Australien ziehen und sich dort eine Farm im Outback kaufen. „Ayda erzählte mir, dass sie eine Art Eingebung hatte und glaubt in Australien alt zu werden. Ich habe nach geeigneten Plätzen im Outback geschaut, vielleicht eine Farm“, so Robbie im Interview. Diese Liebe kennt wirklich keine Grenzen…

    No tags for this post.

    September 18th, 2009 | in VIP News | Leave a comment |

    Eine der erfolgreichsten Bands der 60er hat seine Sängerin verloren. Mary Travers starb gestern Abend im Alter von 72 Jahren an den Folgen der Chemotherapie. Im Jahr 2005 wurde bei der Folksängerin Krebs diagnostiziert. Sie hinterlässt Ehemann und zwei Töchter.

    No tags for this post.