Home | Contact Us | FAQ | Search & Site Map | Link to Us
Sign In | Join | Other 45 Sites in Network
HomeAnnouncementsFree MagazinesWhite PapersSubmit Content
Discussion GroupsASP.NETWindows FormsLanguages.NET FrameworkVisual Studio.NET
Articles.NET FrameworkASP.NETToolsWindows Forms
.NET DirectoryOpen Source ProjectsUser GroupsWeb Resources
Related Topics
Visual Basic 6SQL ServerMS AccessOther DB ProductsMS Server ProductsMore Topics ...

.NET Forum / ASP.NET / Mobile / April 2004

Tip: Looking for answers? Try searching our database.

Inheritanse, insertions and not only that

Thread view: 
Enable EMail Alerts  Start New Thread
Thread rating: 
Dmitri Shvetsov - 07 Apr 2004 00:53 GMT
Hi All,

I post this message in three newsgroups, maybe somebody can say something
helpful.

The ASP.NET C# Web app consists of two parts - the Mobile part (PDA) and the
regular desktop browser (2000/XP) part. The business logic of both parts is
absolutely the same. I don't want to make a full copy of the business logic
in both parts but it seems to me that I don't have any choice. What's done
now. I created an initial page, this page is empty, it just detects the
remote browser version and redirects the program's flow to the required
part - for PDA browser or for 2k/XP browser.

I made both sets of pages almost in the same manner, the controls are
originally different, Mobile and Regular, but these controls are having the
same names and can be managed by the same business logic, thanks to VS for
this flexibility, I made a full copy of a business logic for both sets of
pages and it works.

I hate this solution. If I need to change something I need to change both
codes and keep in mind what code has already been changed and why.

If I could use the inheritance in this case it would be excellent, but I
can't, because VS doesn't support the video inheritance yet, maybe in
future, but nobody promised yet. I use a lot of controls in the logic and
can't make a root class because in this case all these controls will not be
visually inherited, and as I wrote above the origins of these controls are
different - Mobile and Regular.

I can't use #INCLUDE like in C++ to include the same parts of the source
codes. Why? I hate that in VS. Lazy programmers or what? Future versions?..

What I'm having now are almost same class files, excluding the
initialization parts that the Visual Studio generated for the different
controls.

What can I do to cut off the same code from two different places and maybe
to import it from some external file, one for two different class files?
It's terrible but I didn't see that the current version of VS can support
something like #INSERT or #IMPORT except for help files.

Please, help, any ideas will be appreciated.

Dmitri.
Michael Mayer [C# MVP] - 10 Apr 2004 02:39 GMT
> Hi All,
>
> The ASP.NET C# Web app consists of two parts - the Mobile part (PDA) and the
> regular desktop browser (2000/XP) part. The business logic of both parts is
> absolutely the same. I don't want to make a full copy of the business logic
> in both parts but it seems to me that I don't have any choice.

Generally, "business" logic can be shared assuming you structure your app
such that presentation and business logic are kept separate.

My guess is that you need to refactor your code such that as much common
functionality is encapsulated in real "business" classes. These classes will
not know about presentation stuff, but are used by the presentation classes.

Take a login form, for instance. You would probably make a:
desktop/login.aspx and desktop/login.aspx.cs
and also
mobile/login.aspx and mobile/login.aspx.cs

Both of these pages will have text boxes for username, password, and a
button to login. The event handler for that button click event on each page
should probably instantiate and call a method in a third business class:

void button_click (object sender, EventArgs args) {
   LoginLogic loginLogic = new LoginLogic();
   if (loginLogic.LoginUser(username.text, password.text)) {
       Response.Redirect(loggedInPage);
   } else {
       Response.Redirect(failedPage);
   }
}

that third class (LoginLogic) will have all your real business logic. Your
presentation classes, then, can hopefully be kept quite simple.

You can go further and create a common presentation helper class that can
take on even more of the common functionality.  For instance:

public class CommonLogin {

   private Page currentPage;

   public CommonLogin (Page page) {
       currentPage = page;
   }

   public void HandleLoginClick(sender object, EventArgs args) {
       LoginLogic loginLogic = new LoginLogic();
       if (loginLogic.LoginUser(username.text, password.text)) {
           currentPage.Response.Redirect(loggedInPage);
       } else {
           currentPage.Response.Redirect(failedPage);
       }
   }
}

then in your two aspx.cs pages, you'd create an instance of CommonLogin, and
add event handlers to it. something like:

   button.clicked += new EventHandler (commonLogin.HandleLoginClick);

Please note, all above code was written in the e-mail client, so I'm sure
there are many syntax problems. Hopefully, though, it will help you get
started.

Signature

Mike Mayer, C# MVP
mike@mag37.com
http://www.mag37.com/csharp/


Free Magazines

Get these publications absolutely FREE for up to 12 months. There are no hidden fees and no obligation. Simply choose a title, complete the application form and submit it. Read more ...

Oracle MagazineNetwork ComputingComputer WorldBio-IT WorldeWeekInformation WeekInfosecurity
 
Sign In
Join
My Latest Posts
My Monitored Threads
My Blog
My Photo Gallery
My Profile
My Homepage

Start New Thread
Enable EMail Alerts
Rate this Thread



©2008 Advenet LLC   Privacy Policy - Terms of Use
This website includes both content owned or controlled by Advenet as well as content owned or controlled by third parties.