Click here to Skip to main content
Click here to Skip to main content

ASCX Control Parser

, 23 Apr 2002
Rate this:
Please Sign up or sign in to vote.
A program that allows you to convert .ascx User Controls into redistributable controls
<!-- Download Links --> <!-- Add the rest of your HTML here -->

Introduction

Have you ever wanted to turn a .ASCX file into a distributable control? This program generates the source code for an .ASCX file so that you can compile it without having to distribute the .ASCX file. It comes close to simulating how the Page.LoadControl ("asdf.ascx") works.

Usage:

  • Run the exe file, paste in the ascx code into the textbox.
  • Choose the output class name (it will be created in the ASP namespace - but you can change this manually)
  • The "Has base class?" checkbox sets the parser to declare the controls or not. If this is ticked then the base class should have declared each control already.
  • Click go, and the C# code will be outputted in the same textbox.
  • Put the code into a new class in a web application and hopefully it should compile.
  • To add the code to a page you would do this (Assuming that the class was called CDefault and the namespace was left as ASP):
    //=======================================================
    private void Page_Load(object sender, System.EventArgs e)
    {
     // Put user code to initialize the page here
     Control c = new ASP.CDefault();
     this.Controls.Add ( C );
    }
    //=======================================================
    

Known issues: 

  • Compiler directives are ignored so registering controls other than asp controls (asp: namespace) must be done manually. You may have to do some editing on the output to suit your needs (such as code-behind class, etc).

  • List properties are not loaded properly. For example, the property Font-Names on a label control is actually a string list (string[]). The parser can't tell if a property is a list because it can't always do reflection on the type (any ideas how to fix this?).

TODO:

  • Add a VB.NET output, currently the output is only written for C#.
  • Make it a Visual Studio Add-In.
  • Recognise compiler directives.

Registration

If you like it, please send an email to bvk@villagechief.com

If you make any changes or additions, please send them to me at the above email address.

Copyright and License

This is freeware to do with as you see fit. The author accepts no responsibility for any damage or data loss caused by this program.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

About the Author

Ben van Klinken

United States United States
No Biography provided

Comments and Discussions

 
Generalhmmm PinmemberLawrence Botley13-Nov-06 10:03 
GeneralRe: hmmm Pinmemberkelasings15-Sep-07 15:30 
QuestionRe: hmmm Pinmemberstixoffire5-May-08 6:59 
GeneralRe: hmmm Pinmemberstixoffire5-May-08 7:29 
GeneralQuick Update with VB PinmemberTodd77777722-Feb-06 15:51 

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 | Mobile
Web02 | 2.8.140721.1 | Last Updated 24 Apr 2002
Article Copyright 2002 by Ben van Klinken
Everything else Copyright © CodeProject, 1999-2014
Terms of Service
Layout: fixed | fluid