Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • World
  • Users
  • Groups
Skins
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Code Project
  1. Home
  2. Other Discussions
  3. The Weird and The Wonderful
  4. Austin Danger Powers

Austin Danger Powers

Scheduled Pinned Locked Moved The Weird and The Wonderful
38 Posts 17 Posters 0 Views 1 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • A AspDotNetDev

    Luc Pattyn wrote:

    How about the code?

    Ok, I'll construct the N-name control. The user can enter any number of name parts, and select (from a drop-down) the type each name part is. It will look a bit like this:

    [First v] _________
    [Middle v] _________
    [Last v] _________
    [Freak v] _________

    [Add Name Part]

    Of course, there will be validation rules (e.g., last names cannot appear before first names). Happy now? :rolleyes:

    Flummery:

    This is not the age of reason, this is the age of flummery, and the day of the devious approach. Reason’s gone into the backrooms where it works to devise means by which people can be induced to emote in the desired direction.

    C Offline
    C Offline
    CHLane
    wrote on last edited by
    #21

    Hmmm. This looks to be a Power-ful example for making a case for compiler localization: if you want an executable for say Tagalog, just change your display language in VS and re-compile. The compiler would pull in different rules for name construction based on Phillipine conventions. Then voila! You have no need to re-write your logic.

    1 Reply Last reply
    0
    • F Fabio Franco

      I think it's very weird in some countries there is the culture of splitting First and Last names. Some web sites/places don't even have middle name field. I wonder why this is, here in Brazil it's always one field for the name only. Is there any need for splitting the names? I find it more confusing only. Worse for the websites that have only first and last names. Do I use: "Franco, Fábio dos Santos" or "dos Santos Franco, Fábio". Here everywhere, it's only one field for registering anywhere, field splitting were never missed.

      A Offline
      A Offline
      AspDotNetDev
      wrote on last edited by
      #22

      It can be useful to split names. That way, companies can send you emails and address you by your first name (or given name, or whatever name part it is common to address people by in a given region). So, they can say "Dear Joe" rather than "Dear Joe Blo III". It is also useful to let the user know that all portions of the name must be entered. For example, if entering credit card details, it is a handy reminder to users to have first/last name so they know they must enter their whole name. While unfair to those with different naming conventions, first/middle/last is the standard for English websites (some add title and others, but the main thing is first/middle/last). It might be best if they allowed for a toggle, so you could switch between first/middle/last or just "full name".

      Flummery:

      This is not the age of reason, this is the age of flummery, and the day of the devious approach. Reason’s gone into the backrooms where it works to devise means by which people can be induced to emote in the desired direction.

      F 1 Reply Last reply
      0
      • A AspDotNetDev

        Private Function GetFullName(firstName As String, middleName As String, lastName As String) As String

        ' Variables.
        Dim fullName As String
        Dim firstEmpty As String = String.IsNullOrEmpty(firstName)
        Dim middleEmpty As String = String.IsNullOrEmpty(middleName)
        Dim lastEmpty As String = String.IsNullOrEmpty(lastName)
        
        
        ' Combine name parts into full name.
        If firstEmpty Then
        	If middleEmpty Then
        		' Powers.
        		fullName = lastName
        	Else
        		If lastEmpty Then
        			' Danger.
        			fullName = middleName
        		Else
        			' Powers (ignore middle name).
        			fullName = lastName
        		End If
        	End If
        Else
        	If lastEmpty Then
        		' Austin (ignore middle name).
        		fullName = firstName
        	Else
        		If middleEmpty Then
        			' Austin Powers.
        			fullName = String.Format("{0} {1}", firstName, lastName)
        		Else
        			' Austin Danger Powers.
        			fullName = String.Format("{0} {1} {2}", firstName, middleName, lastName)
        		End If
        	End If
        End If
        
        
        ' Return full name.
        Return fullName
        

        End Function

        I wasn't sure if I should put this in "Clever Code" or "Hall of Shame". :)

        Flummery:

        This is not the age of reason, this is the age of flummery, and the day of the devious approach. Reason’s gone into the backrooms where it works to devise means by which people can be induced to emote in the desired direction.

        _ Offline
        _ Offline
        _Erik_
        wrote on last edited by
        #23

        AspDotNetDev wrote:

        I wasn't sure if I should put this in "Clever Code" or "Hall of Shame".

        Hall of shame, definitely, specially considering that this line would do the same job:

        Return String.Format("{0} {1} {2}", firstName, middleName, lastName).Replace(" ", " ").Trim()

        Yes, it works even if firstName, middleName and/or lastName are null. Edit: Forgot the Replace

        A T 2 Replies Last reply
        0
        • A AspDotNetDev

          G-Tek wrote:

          implicit conversion is not really the worst part of the function, is it?

          That would get my vote for worst part. What part of the function would you vote worst part? Maybe we should suggest a Code Project survey. :rolleyes:

          Flummery:

          This is not the age of reason, this is the age of flummery, and the day of the devious approach. Reason’s gone into the backrooms where it works to devise means by which people can be induced to emote in the desired direction.

          G Offline
          G Offline
          G Tek
          wrote on last edited by
          #24

          I guess as I look at it, why write 10 lines of code when you can write one? I understand that readability is always a factor, but there just seems to be a lot of code there for a simple function.

          1 Reply Last reply
          0
          • A AspDotNetDev

            It can be useful to split names. That way, companies can send you emails and address you by your first name (or given name, or whatever name part it is common to address people by in a given region). So, they can say "Dear Joe" rather than "Dear Joe Blo III". It is also useful to let the user know that all portions of the name must be entered. For example, if entering credit card details, it is a handy reminder to users to have first/last name so they know they must enter their whole name. While unfair to those with different naming conventions, first/middle/last is the standard for English websites (some add title and others, but the main thing is first/middle/last). It might be best if they allowed for a toggle, so you could switch between first/middle/last or just "full name".

            Flummery:

            This is not the age of reason, this is the age of flummery, and the day of the devious approach. Reason’s gone into the backrooms where it works to devise means by which people can be induced to emote in the desired direction.

            F Offline
            F Offline
            Fabio Franco
            wrote on last edited by
            #25

            AspDotNetDev wrote:

            companies can send you emails and address you by your first name

            someString.Split(' ')[0];

            AspDotNetDev wrote:

            let the user know that all portions of the name must be entered

            lblName.Text = "Full Name:"

            I know that name splitting has it's usefulness, like displaying in formats like "Last, First Name" the way the user wants, but I believe single field names benefits outweighs by far the benefits of multiple field names. Not only on the functional perspective, but also on development. It's much simpler to have only one column on the database to hold a name. A better solution would indeed be a toggle, but then, that adds overhead to development.

            A 1 Reply Last reply
            0
            • A AspDotNetDev

              G-Tek wrote:

              implicit conversion is not really the worst part of the function, is it?

              That would get my vote for worst part. What part of the function would you vote worst part? Maybe we should suggest a Code Project survey. :rolleyes:

              Flummery:

              This is not the age of reason, this is the age of flummery, and the day of the devious approach. Reason’s gone into the backrooms where it works to devise means by which people can be induced to emote in the desired direction.

              P Offline
              P Offline
              Paladin2000
              wrote on last edited by
              #26

              Dim firstEmpty As String = String.IsNullOrEmpty(firstName)

              ...

              If firstEmpty Then

              What's really horrible is that it's not only doing an unnecessary implicit conversion, it's converting it back implicitly with each "If" statement. That may not be a big performance hit here, but put this in an iteration for a few thousand/million loop cycles and I'm sure it would add up (unless maybe the compiler corrects for this mistake, I'm not certain). That gets *my* vote...

              1 Reply Last reply
              0
              • _ _Erik_

                AspDotNetDev wrote:

                I wasn't sure if I should put this in "Clever Code" or "Hall of Shame".

                Hall of shame, definitely, specially considering that this line would do the same job:

                Return String.Format("{0} {1} {2}", firstName, middleName, lastName).Replace(" ", " ").Trim()

                Yes, it works even if firstName, middleName and/or lastName are null. Edit: Forgot the Replace

                A Offline
                A Offline
                AspDotNetDev
                wrote on last edited by
                #27

                Indeed, that may act very similar. However, here are two problems I see with that code:

                1. What if, for whatever reason, a user has two consecutive spaces in their first name? Given the variety of cultures, I wouldn't discount this.
                2. This version creates several extra and unnecessary strings.
                3. Unnecessary CPU time spent scanning the name parts (first/middle/last) for space to replace.

                Still, with how compact it is, I'd say those are fine trade offs.

                Flummery:

                This is not the age of reason, this is the age of flummery, and the day of the devious approach. Reason’s gone into the backrooms where it works to devise means by which people can be induced to emote in the desired direction.

                1 Reply Last reply
                0
                • F Fabio Franco

                  AspDotNetDev wrote:

                  companies can send you emails and address you by your first name

                  someString.Split(' ')[0];

                  AspDotNetDev wrote:

                  let the user know that all portions of the name must be entered

                  lblName.Text = "Full Name:"

                  I know that name splitting has it's usefulness, like displaying in formats like "Last, First Name" the way the user wants, but I believe single field names benefits outweighs by far the benefits of multiple field names. Not only on the functional perspective, but also on development. It's much simpler to have only one column on the database to hold a name. A better solution would indeed be a toggle, but then, that adds overhead to development.

                  A Offline
                  A Offline
                  AspDotNetDev
                  wrote on last edited by
                  #28

                  How would your code handle a user who enters: "Mr. Fabio Franco, Ph.D."? :) Or how about these:

                  • "Mr Fabio Franco, Phd"
                  • "Mr Fabio Franco the first, phd cna"
                  • "Mrs. Fabio Franco"
                  • "Fabio Franco, Mr"
                  • "Fabio Franco III"
                  • "Fabio"

                  There is quite a bit of variation out there, and I'm sure more variation I don't know about in other cultures. Users do funny things when you let them (try to) think for themselves.

                  Flummery:

                  This is not the age of reason, this is the age of flummery, and the day of the devious approach. Reason’s gone into the backrooms where it works to devise means by which people can be induced to emote in the desired direction.

                  F 1 Reply Last reply
                  0
                  • A AspDotNetDev

                    How would your code handle a user who enters: "Mr. Fabio Franco, Ph.D."? :) Or how about these:

                    • "Mr Fabio Franco, Phd"
                    • "Mr Fabio Franco the first, phd cna"
                    • "Mrs. Fabio Franco"
                    • "Fabio Franco, Mr"
                    • "Fabio Franco III"
                    • "Fabio"

                    There is quite a bit of variation out there, and I'm sure more variation I don't know about in other cultures. Users do funny things when you let them (try to) think for themselves.

                    Flummery:

                    This is not the age of reason, this is the age of flummery, and the day of the devious approach. Reason’s gone into the backrooms where it works to devise means by which people can be induced to emote in the desired direction.

                    F Offline
                    F Offline
                    Fabio Franco
                    wrote on last edited by
                    #29

                    I get what you mean, users thinking by themselves are not good :~, but I think design can solve those issues :) : Title: Full Name: Again, it works so well here that I'm still to find a place in .com.br domain that asks for a multi field name. I don't there's magic bullet for anything, but I still believe that my argument stands, that single field names benefits outweighs multi-field names. I think in US is more of a culture of "most do this way, so we're not changing", although I've seen several single field name cases already.

                    1 Reply Last reply
                    0
                    • _ _Erik_

                      AspDotNetDev wrote:

                      I wasn't sure if I should put this in "Clever Code" or "Hall of Shame".

                      Hall of shame, definitely, specially considering that this line would do the same job:

                      Return String.Format("{0} {1} {2}", firstName, middleName, lastName).Replace(" ", " ").Trim()

                      Yes, it works even if firstName, middleName and/or lastName are null. Edit: Forgot the Replace

                      T Offline
                      T Offline
                      TorstenFrings
                      wrote on last edited by
                      #30

                      You missed the condition, that the middle name should be omitted if first or last is missing... :cool:

                      A 1 Reply Last reply
                      0
                      • L Luc Pattyn

                        There is a small change in the specs, we now have two more optional (middle?) initials. Please adapt your code... :)

                        Luc Pattyn [Forum Guidelines] [My Articles] Nil Volentibus Arduum

                        Please use <PRE> tags for code snippets, they preserve indentation, improve readability, and make me actually look at the code.

                        B Offline
                        B Offline
                        BobJanova
                        wrote on last edited by
                        #31

                        Yeah, while the forename-surname thing is kind of fair enough for many applications (most of us do work in English language countries), even in those, lots of people have more than one middle name.

                        1 Reply Last reply
                        0
                        • A AspDotNetDev

                          Private Function GetFullName(firstName As String, middleName As String, lastName As String) As String

                          ' Variables.
                          Dim fullName As String
                          Dim firstEmpty As String = String.IsNullOrEmpty(firstName)
                          Dim middleEmpty As String = String.IsNullOrEmpty(middleName)
                          Dim lastEmpty As String = String.IsNullOrEmpty(lastName)
                          
                          
                          ' Combine name parts into full name.
                          If firstEmpty Then
                          	If middleEmpty Then
                          		' Powers.
                          		fullName = lastName
                          	Else
                          		If lastEmpty Then
                          			' Danger.
                          			fullName = middleName
                          		Else
                          			' Powers (ignore middle name).
                          			fullName = lastName
                          		End If
                          	End If
                          Else
                          	If lastEmpty Then
                          		' Austin (ignore middle name).
                          		fullName = firstName
                          	Else
                          		If middleEmpty Then
                          			' Austin Powers.
                          			fullName = String.Format("{0} {1}", firstName, lastName)
                          		Else
                          			' Austin Danger Powers.
                          			fullName = String.Format("{0} {1} {2}", firstName, middleName, lastName)
                          		End If
                          	End If
                          End If
                          
                          
                          ' Return full name.
                          Return fullName
                          

                          End Function

                          I wasn't sure if I should put this in "Clever Code" or "Hall of Shame". :)

                          Flummery:

                          This is not the age of reason, this is the age of flummery, and the day of the devious approach. Reason’s gone into the backrooms where it works to devise means by which people can be induced to emote in the desired direction.

                          J Offline
                          J Offline
                          Jassim Makki
                          wrote on last edited by
                          #32

                          wahaha this a "Hall of Shame" code indeed XD

                          1 Reply Last reply
                          0
                          • L Luc Pattyn

                            There is a small change in the specs, we now have two more optional (middle?) initials. Please adapt your code... :)

                            Luc Pattyn [Forum Guidelines] [My Articles] Nil Volentibus Arduum

                            Please use <PRE> tags for code snippets, they preserve indentation, improve readability, and make me actually look at the code.

                            H Offline
                            H Offline
                            HaBiX
                            wrote on last edited by
                            #33

                            lol

                            1 Reply Last reply
                            0
                            • T TorstenFrings

                              You missed the condition, that the middle name should be omitted if first or last is missing... :cool:

                              A Offline
                              A Offline
                              AspDotNetDev
                              wrote on last edited by
                              #34

                              Nope, if a middle name is all you have to call somebody, then you might as well call them that.

                              Chris Maunder wrote:

                              Fixign now.

                              But who's fixing the fixign?

                              T 1 Reply Last reply
                              0
                              • A AspDotNetDev

                                Nope, if a middle name is all you have to call somebody, then you might as well call them that.

                                Chris Maunder wrote:

                                Fixign now.

                                But who's fixing the fixign?

                                T Offline
                                T Offline
                                TorstenFrings
                                wrote on last edited by
                                #35

                                What I meant was: GetFullName(null, "middle", "last") => "last" GetFullName("first", "middle", null) => "first" isn't accomplished by your expression... but as well doesn't justify the code of horror in the OP

                                A 1 Reply Last reply
                                0
                                • T TorstenFrings

                                  What I meant was: GetFullName(null, "middle", "last") => "last" GetFullName("first", "middle", null) => "first" isn't accomplished by your expression... but as well doesn't justify the code of horror in the OP

                                  A Offline
                                  A Offline
                                  AspDotNetDev
                                  wrote on last edited by
                                  #36

                                  Actually, I am the OP and I didn't catch that. Take some 5's. :thumbsup:

                                  Chris Maunder wrote:

                                  Fixign now.

                                  But who's fixing the fixign?

                                  1 Reply Last reply
                                  0
                                  • P Paladin2000

                                    AspDotNetDev wrote:

                                    Dim firstEmpty As String = String.IsNullOrEmpty(firstName)

                                    String.IsNullOrEmpty returns "bool"... How are you assigning it to a string variable..? :confused:

                                    D Offline
                                    D Offline
                                    DragonsRightWing
                                    wrote on last edited by
                                    #37

                                    Timothy CIAN wrote:

                                    String.IsNullOrEmpty returns "bool"... How are you assigning it to a string variable..? :confused:

                                    I was wondering the same thing - the line shouldn't compile (and doesn't, when I test it)!

                                    1 Reply Last reply
                                    0
                                    • L Luc Pattyn

                                      Here it is pretty normal to have several "first names", in Dutch we actually call them firstnames (plural), although first, second, third, etc. would be more logical. I have four. So we don't really have a middle name or middle initial, when you ask me for a middle initial you'd get three of them. And all that is without double or composite names. How about the code? :)

                                      Luc Pattyn [Forum Guidelines] [My Articles] Nil Volentibus Arduum

                                      Please use <PRE> tags for code snippets, they preserve indentation, improve readability, and make me actually look at the code.

                                      B Offline
                                      B Offline
                                      Blake Miller
                                      wrote on last edited by
                                      #38

                                      The multiple names is not SOOO uncommon here in the U.S.A. anymore either. The nanas were arguing about the middle name for our second daugher, so we just gave her "Amber Ann" as the middle name!

                                      1 Reply Last reply
                                      0
                                      Reply
                                      • Reply as topic
                                      Log in to reply
                                      • Oldest to Newest
                                      • Newest to Oldest
                                      • Most Votes


                                      • Login

                                      • Don't have an account? Register

                                      • Login or register to search.
                                      • First post
                                        Last post
                                      0
                                      • Categories
                                      • Recent
                                      • Tags
                                      • Popular
                                      • World
                                      • Users
                                      • Groups