News:

Holy shit, it's 2018 2019 2020 2021 2022 2023 2024, and the US isn't a fascist country! What a time to be alive.

Main Menu

C#: Throwing warnings?

Started by Joe, November 19, 2007, 01:53:14 PM

Previous topic - Next topic

0 Members and 3 Guests are viewing this topic.

Joe

In C#, is there any way to throw a warning, like the ones the compiler gives you? Sort of like an exception, only not a fatal error, and the function can continue? For example, in my my connection sanity, I'd like to do something like this:

            // Check for an illegal client.
            if (!( m_sClient.Equals("RATS") || m_sClient.Equals("PXES") || m_sClient.Equals("NB2W") || m_sClient.Equals("VD2D") ||
                   m_sClient.Equals("PX2D") || m_sClient.Equals("3RAW") || m_sClient.Equals("PX3W")))
                throw new ArgumentOutOfRangeException(null, "You have not selected a valid client. See the readme for more information.");

            // LOOK AT ME
            if (m_sClient.Equals("RATS") || m_sClient.Equals("PXES"))
                throw new ConnectionWarning("StarCraft and Brood War are currently subject to checks by Blizzard's Wardent technology, "
                    + "causing possible disconnections after a few minutes.");
            // LOOK AT ME

            // Check if they're attempting to use an SPR-related client (unsupported).
            if (m_sClient.Equals("3RAW") || m_sClient.Equals("PX3W"))
                throw new ArgumentOutOfRangeException(null, "The product you have selected has not had it's logon method implemented.");


(See the LOOK AT ME part in the middle)

Does anyone know of a way to do this?
Quote from: Camel on June 09, 2009, 04:12:23 PMI'd personally do as Joe suggests

Quote from: AntiVirus on October 19, 2010, 02:36:52 PM
You might be right about that, Joe.


MyndFyre

I think you really need to take a look at your design.  Should something so deep as your connection, which has several layers of abstraction, be communicating with your user interface in such a high level?  Probably not.

Exceptions are supposed to be raised in exceptional circumstances.  Clearly this isn't such a case.

An alternative might be to create a "Warning" event:


// outside of classes
public delegate void WarningEventHandler(object sender, WarningEventArgs e);
public class WarningEventArgs : EventArgs
{
    private string m_msg;

    public WarningEventArgs(string warning)
    {
        m_msg = warning;
    }

    public string Message { get { return m_msg; } }
}

// in the class
[field: NonSerialized]
public event WarningEventHandler Warning;
protected virtual void OnWarning(WarningEventArgs e)
{
    if (Warning != null)
        Warning(this, e);
}

// in your method
if (string.Compare(m_sClient, "RATS", true) == 0 || string.Compare(m_sClient, "PXES", true) == 0)
    OnWarning(new WarningEventArgs("Starcraft and Brood War..."));
Quote from: Joe on January 23, 2011, 11:47:54 PM
I have a programming folder, and I have nothing of value there

Running with Code has a new home!

Quote from: Rule on May 26, 2009, 02:02:12 PMOur species really annoys me.

Newby

Quote from: Joex86] link=topic=10676.msg136245#msg136245 date=1195498394]
            // Check for an illegal client.
            if (!( m_sClient.Equals("RATS") || m_sClient.Equals("PXES") || m_sClient.Equals("NB2W") || m_sClient.Equals("VD2D") ||
                   m_sClient.Equals("PX2D") || m_sClient.Equals("3RAW") || m_sClient.Equals("PX3W")))
                throw new ArgumentOutOfRangeException(null, "You have not selected a valid client. See the readme for more information.");

...

            // Check if they're attempting to use an SPR-related client (unsupported).
            if (m_sClient.Equals("3RAW") || m_sClient.Equals("PX3W"))
                throw new ArgumentOutOfRangeException(null, "The product you have selected has not had it's logon method implemented.");


Why is it that at first you call 3RAW and PX3W invalid... and then proceed to mention that you can't login with them? Wouldn't it make sense that since they don't exist, their login method doesn't exist either?

You should probably stop having all that sex, it's making you retarded.

A good program should simply pick the reversed 4-letter names for the products and... reverse them back on its own. Don't rely on telling the user to pick a 'real' product because as far as they're concerned, RATS could very well be what they used in another program, so they'll just go back to it.
- Newby
http://www.x86labs.org

Quote[17:32:45] * xar sets mode: -oooooooooo algorithm ban chris cipher newby stdio TehUser tnarongi|away vursed warz
[17:32:54] * xar sets mode: +o newby
[17:32:58] <xar> new rule
[17:33:02] <xar> me and newby rule all

Quote from: Rule on June 30, 2008, 01:13:20 PM
Quote from: CrAz3D on June 30, 2008, 10:38:22 AM
I'd bet that you're currently bloated like a water ballon on a hot summer's day.

That analogy doesn't even make sense.  Why would a water balloon be especially bloated on a hot summer's day? For your sake, I hope there wasn't too much logic testing on your LSAT. 

Joe

Quote from: Newby on November 19, 2007, 07:46:24 PM
Why is it that at first you call 3RAW and PX3W invalid... and then proceed to mention that you can't login with them? Wouldn't it make sense that since they don't exist, their login method doesn't exist either?

You should probably stop having all that sex, it's making you retarded.

You should get laid. You missed the not operation.

Quote from: Newby on November 19, 2007, 07:46:24 PM
A good program should simply pick the reversed 4-letter names for the products and... reverse them back on its own. Don't rely on telling the user to pick a 'real' product because as far as they're concerned, RATS could very well be what they used in another program, so they'll just go back to it.

I'm really touched that you approve of my coding.
Quote from: Camel on June 09, 2009, 04:12:23 PMI'd personally do as Joe suggests

Quote from: AntiVirus on October 19, 2010, 02:36:52 PM
You might be right about that, Joe.


Warrior

Quote from: Joex86] link=topic=10676.msg136301#msg136301 date=1195541994]
Quote from: Newby on November 19, 2007, 07:46:24 PM
Why is it that at first you call 3RAW and PX3W invalid... and then proceed to mention that you can't login with them? Wouldn't it make sense that since they don't exist, their login method doesn't exist either?

You should probably stop having all that sex, it's making you retarded.

You should get laid. You missed the not operation.

Quote from: Newby on November 19, 2007, 07:46:24 PM
A good program should simply pick the reversed 4-letter names for the products and... reverse them back on its own. Don't rely on telling the user to pick a 'real' product because as far as they're concerned, RATS could very well be what they used in another program, so they'll just go back to it.

I'm really touched that you approve of my coding.

You should be touched, because I don't approve of it.

Horrible. F
One must ask oneself: "do I will trolling to become a universal law?" And then when one realizes "yes, I do will it to be such," one feels completely justified.
-- from Groundwork for the Metaphysics of Trolling

MyndFyre

Quote from: Warriorx86] link=topic=10676.msg136305#msg136305 date=1195570177]
You should be touched, because I don't approve of it.
You're saying you touch Joe?  Homo pedophile.
Quote from: Warriorx86] link=topic=10676.msg136305#msg136305 date=1195570177]
Horrible. F
K maddox.
Quote from: Joe on January 23, 2011, 11:47:54 PM
I have a programming folder, and I have nothing of value there

Running with Code has a new home!

Quote from: Rule on May 26, 2009, 02:02:12 PMOur species really annoys me.

Warrior

Quote from: MyndFyrex86/64] link=topic=10676.msg136313#msg136313 date=1195586693]
Quote from: Warriorx86] link=topic=10676.msg136305#msg136305 date=1195570177]
You should be touched, because I don't approve of it.
You're saying you touch Joe?  Homo pedophile.
Quote from: Warriorx86] link=topic=10676.msg136305#msg136305 date=1195570177]
Horrible. F
K maddox.

party poopers poop at parties.
One must ask oneself: "do I will trolling to become a universal law?" And then when one realizes "yes, I do will it to be such," one feels completely justified.
-- from Groundwork for the Metaphysics of Trolling

Camel

I prefer to read and write the product id as a DWORD, so I can switch() on it.

<Camel> i said what what
<Blaze> in the butt
<Camel> you want to do it in my butt?
<Blaze> in my butt
<Camel> let's do it in the butt
<Blaze> Okay!

MyndFyre

Quote from: Camel on November 20, 2007, 08:06:40 PM
I prefer to read and write the product id as a DWORD, so I can switch() on it.

Good thing that C# can switch on strings. :)
Quote from: Joe on January 23, 2011, 11:47:54 PM
I have a programming folder, and I have nothing of value there

Running with Code has a new home!

Quote from: Rule on May 26, 2009, 02:02:12 PMOur species really annoys me.

Joe

Quote from: MyndFyrex86/64] link=topic=10676.msg136343#msg136343 date=1195616254]
Quote from: Camel on November 20, 2007, 08:06:40 PM
I prefer to read and write the product id as a DWORD, so I can switch() on it.

Good thing that C# can switch on strings. :)

Oh. Hehe. Thanks for telling me that a few months ago. :P
Quote from: Camel on June 09, 2009, 04:12:23 PMI'd personally do as Joe suggests

Quote from: AntiVirus on October 19, 2010, 02:36:52 PM
You might be right about that, Joe.


Camel

The purpose of a switch statement is to avoid giving bias to the options at the top of the if..else if.. tree. Allowing a switch statement to accept anything beyond constant integer base types for its cases is just silly.

<Camel> i said what what
<Blaze> in the butt
<Camel> you want to do it in my butt?
<Blaze> in my butt
<Camel> let's do it in the butt
<Blaze> Okay!

Newby

Quote from: Joex86] link=topic=10676.msg136301#msg136301 date=1195541994]
You should get laid. You missed the not operation.

So if they enter "STAR" or "SEXP" it'll say invalid product? That's just as retarded. :|
- Newby
http://www.x86labs.org

Quote[17:32:45] * xar sets mode: -oooooooooo algorithm ban chris cipher newby stdio TehUser tnarongi|away vursed warz
[17:32:54] * xar sets mode: +o newby
[17:32:58] <xar> new rule
[17:33:02] <xar> me and newby rule all

Quote from: Rule on June 30, 2008, 01:13:20 PM
Quote from: CrAz3D on June 30, 2008, 10:38:22 AM
I'd bet that you're currently bloated like a water ballon on a hot summer's day.

That analogy doesn't even make sense.  Why would a water balloon be especially bloated on a hot summer's day? For your sake, I hope there wasn't too much logic testing on your LSAT. 

iago

Quote from: Camel on November 20, 2007, 11:02:26 PM
The purpose of a switch statement is to avoid giving bias to the options at the top of the if..else if.. tree. Allowing a switch statement to accept anything beyond constant integer base types for its cases is just silly.
Huh? That doesn't make any sense! An if/else tree with non-overlapping cases gives no bias, so that reason makes no sense.

The reason you use a switch/case is purely speed and style.

Joe

Quote from: Newby on November 21, 2007, 12:21:02 AM
Quote from: Joex86] link=topic=10676.msg136301#msg136301 date=1195541994]
You should get laid. You missed the not operation.

So if they enter "STAR" or "SEXP" it'll say invalid product? That's just as retarded. :|

See the link. They click StarCraft or StarCraft Expansion in the config dialog. You may notice that I switched the direction of all the product codes after posting this.
Quote from: Camel on June 09, 2009, 04:12:23 PMI'd personally do as Joe suggests

Quote from: AntiVirus on October 19, 2010, 02:36:52 PM
You might be right about that, Joe.


Camel

Quote from: iago on November 21, 2007, 08:32:13 AM
Quote from: Camel on November 20, 2007, 11:02:26 PM
The purpose of a switch statement is to avoid giving bias to the options at the top of the if..else if.. tree. Allowing a switch statement to accept anything beyond constant integer base types for its cases is just silly.
Huh? That doesn't make any sense! An if/else tree with non-overlapping cases gives no bias, so that reason makes no sense.

The reason you use a switch/case is purely speed and style.

No, an if/else tree evaluates the conditions in the order they appear. A switch table with constant base types as its cases uses a jump table, which more appropriate for this case.

In any event, for this particular example, where this code is executed once per execution, it is hardly worth arguing over. As a matter of principle, however, you should at least be aware of how each one works.

<Camel> i said what what
<Blaze> in the butt
<Camel> you want to do it in my butt?
<Blaze> in my butt
<Camel> let's do it in the butt
<Blaze> Okay!