Click here to Skip to main content
11,630,646 members (78,289 online)
Click here to Skip to main content

Visual Studio .NET RSS Viewer with XSL

, 9 Mar 2004 CPOL 48.4K 515 16
Rate this:
Please Sign up or sign in to vote.
Another macro to show an RSS feed in VS.NET, nicely formatted using the CP colors


RSS feeds are more and more popular and as any site that respects itself, CodeProject also provides a nice RSS feed with information about the latest articles.

As Steven Hicks just noticed in the Lounge CodeProject RSS link is not so easy to notice. If you are a real CPA (CodeProjectAdict) you do want to see "What's new on CP" at any moment. And the best place to see it is of course in you VS.Net environment where you spend most of you time anyway. Plus that you don't have to open a new explorer window just to see if there is anything new on CP.

And if you could also see the latest news in the CodeProject style (colors, fonts) it would be even nicer.

Sample screenshot


Thus, to achive this goal I made a small XSL file to translate the RSS from CP to a nice formated HTML webpage that gets displayed inside VS.Net but a simple mouse click.


The macro is based 99% on the one provided by Davy Mitchell in his article Visual Studio .NET RSS Headline Viewer.

    Function GetHTML(ByVal strPage As String) As String

        If strPage.StartsWith("http://") Then
                Dim oReq As System.Net.HttpWebRequest
                Dim oResp As System.Net.HttpWebResponse
                oReq = System.Net.HttpWebRequest.Create(strPage)
                oResp = oReq.GetResponse
                Dim sr As New StreamReader(oResp.GetResponseStream)
                Return sr.ReadToEnd()
                'Do something with your error        
            End Try
        Else    ' local file ?
            Dim sr As StreamReader = New StreamReader(strPage)
            Return sr.ReadToEnd()
        End If

    End Function

    Public Sub RefreshRSS()
            'DESCRIPTION: Grabs headlines and displays them as text.
            Dim RDFText As String
            Dim objTextDoc As TextDocument
            Dim objEP As EditPoint

            'Create a new text document.
            Call DTE.ItemOperations.NewFile("General\Text File")

            'Get a handle to the new document.
            objTextDoc = DTE.ActiveDocument.Object("TextDocument")
            objEP = objTextDoc.StartPoint.CreateEditPoint
            RDFText = GetHTML( & _ 

            objEP.Insert("<?xml-stylesheet type=""text/xsl"" " & _
                  "href=""change.xsl""?>" + vbCrLf)

            RDFText = RDFText.Replace("©", "(c)")



            Dim ItemOp As ItemOperations
            ItemOp = DTE.ItemOperations
            ItemOp.Navigate("file://C:\temp\news.xml", _

        Catch err As System.Exception
        End Try
    End Sub


  • Unzip the files to a folder of your choice (C:\temp) for example.
  • Drop this macro in your macro editor, assign the macro to a button and update the paths in the macro with the path where you unziped the files.
  • Click the button Smile | :) .


This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


About the Author

Corneliu Tusnea
Technical Lead OneSaas - Cloud Integrations Made Easy
Australia Australia

You may also be interested in...

Comments and Discussions

GeneralProblems with special characters Pin
Lpalma10-Jun-05 16:28
memberLpalma10-Jun-05 16:28 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Terms of Use | Mobile
Web02 | 2.8.150723.1 | Last Updated 10 Mar 2004
Article Copyright 2004 by Corneliu Tusnea
Everything else Copyright © CodeProject, 1999-2015
Layout: fixed | fluid