Using an IF statement

Got a LiveCode personal license? Are you a beginner, hobbyist or educator that's new to LiveCode? This forum is the place to go for help getting started. Welcome!

Moderators: FourthWorld, heatherlaine, Klaus, kevinmiller

Post Reply
shawnblc
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 342
Joined: Fri Jun 01, 2012 11:11 pm

Using an IF statement

Post by shawnblc » Thu Sep 12, 2013 4:43 am

Should be getting my book, Programming LiveCode for the Complete Beginner in about a week. ;)

In the meantime...I'm still having issues wrapping my head around a good portion of LC. Example below, in which I'm having issues and don't see where I'm going wrong.

Code: Select all

on mouseUp

   if fld fldEmail = "fldEmail" then     // i have an input box named fldEmail and in my db i have  the same field with an email in it.
         go to stack url "http://domain/1.livecode"
      else
         go to stack url "http://domain/5.livecode"
end if
end mouseUp


dunbarx
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 10386
Joined: Wed May 06, 2009 2:28 pm

Re: Using an IF statement

Post by dunbarx » Thu Sep 12, 2013 5:39 am

Hi.

There is nothing syntactically wrong with your handler, though I would always put object references in quotes (fld "fldEmail")

The handler did not download a stack, though. Is that what you are asking about? The dictionary states that:

If you specify a URL, the stack is downloaded from that URL and displayed. The stack must be in stack file format (that is, not compressed or archived). Stacks opened in this way are treated as unsaved stacks; the long name of such a stack is the same as its abbreviated name, until the stack is saved on a local disk. The downloaded stack is a copy: changes you make to the stack are not automatically made on the server the stack came from. To change the stack on the server, you must save the stack file locally and re-upload it.

Craig Newman

shawnblc
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 342
Joined: Fri Jun 01, 2012 11:11 pm

Re: Using an IF statement

Post by shawnblc » Thu Sep 12, 2013 5:40 am

It's always downloading 1.livecode. Instead of when the email doesn't match downloading 5.livecode.

dave_probertGA6e24
Livecode Opensource Backer
Livecode Opensource Backer
Posts: 328
Joined: Mon Dec 05, 2011 5:34 pm
Contact:

Re: Using an IF statement

Post by dave_probertGA6e24 » Thu Sep 12, 2013 6:09 am

Hi,

Try this and see what happens:

Code: Select all

on mouseUp
  if fld "fldEmail" is "fldEmail" then
    go to stack url "http://domain/1.livecode"
  else
    go to stack url "http://domain/5.livecode"
  end if
end mouseUp
It might work - or not!
Coding in the Sun - So much Fun.
Visit http://electronic-apps.info for released App information.

shawnblc
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 342
Joined: Fri Jun 01, 2012 11:11 pm

Re: Using an IF statement

Post by shawnblc » Thu Sep 12, 2013 6:16 am

dave_probertGA6e24 wrote:Hi,

Try this and see what happens:

Code: Select all

on mouseUp
  if fld "fldEmail" is "fldEmail" then
    go to stack url "http://domain/1.livecode"
  else
    go to stack url "http://domain/5.livecode"
  end if
end mouseUp
It might work - or not!
Same thing. Always goes to 1.livecode. No matter what the email. In the database I have two different emails, one for each card. Doesn't matter what I put in the field always 1.livecode.

Simon
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 3901
Joined: Sat Mar 24, 2007 2:54 am

Re: Using an IF statement

Post by Simon » Thu Sep 12, 2013 7:00 am

I think there is much missing here.
The whole DB thing is questionable, not sure:
...in my db i have the same field...
What is a "field" in a DB?

Now, if you said you extracted the DB data into a liveCode field and then do your comparison then there is a start.

Simon
I used to be a newbie but then I learned how to spell teh correctly and now I'm a noob!

dave_probertGA6e24
Livecode Opensource Backer
Livecode Opensource Backer
Posts: 328
Joined: Mon Dec 05, 2011 5:34 pm
Contact:

Re: Using an IF statement

Post by dave_probertGA6e24 » Thu Sep 12, 2013 8:51 am

Hi,

Time to do some debugging...

Code: Select all

on mouseUp
  put fld "fldEmail" into xxxxx
  put "FLD EMAIL:" && xxxxxx into msg
  if xxxxx is "fldEmail" then
...
in the messagebox you should see what it thinks is in fld "fldEmail".

It'll probably help you a bit.

Cheers,
Dave
Coding in the Sun - So much Fun.
Visit http://electronic-apps.info for released App information.

AndyP
Posts: 634
Joined: Wed Aug 27, 2008 12:57 pm
Contact:

Re: Using an IF statement

Post by AndyP » Thu Sep 12, 2013 9:04 am

Hi, try adding an extra field "EmailfromDatabase" so you can see better what is being retrieved from the database then compare the two fields.

on mouseUp

put fldEmail into fld "EmailfromDatabase" // add new field for testing so that you can see what is actually being retrieved from the database.

if fld "fldEmail" = fld "EmailfromDatabase" then // i have an input box named fldEmail and in my db i have the same field with an email in it.
go to stack url "http://domain/1.livecode"
else
go to stack url "http://domain/5.livecode"
end if
end mouseUp
Andy .... LC CLASSIC ROCKS!

Klaus
Posts: 14249
Joined: Sat Apr 08, 2006 8:41 am
Contact:

Re: Using an IF statement

Post by Klaus » Thu Sep 12, 2013 4:45 pm

HI shawn,

Andy is 100% correct!

All the time you are checking the content (text) of your field "fldEmail" againt the STRING (text) "fldEmail"
but you aren't referencing the actual value from that field in your database!


Best

Klaus

Post Reply