Title | Ado-files and string comparisons | |
Author | Nicholas J. Cox, Durham University, UK |
Sometimes programs defined by ado-files produce puzzling output when called with an if condition followed by a string comparison.
This can usually be traced to a bug (or limitation) affecting commands defined by programs with version less than 6.0. Such programs have an early line something like
version 5.0
which may be seen by looking at the code in a text editor or by typing the file
type location/whatever.ado
This version statement (see [P] version or the online help for version) means that what follows is interpreted with Stata behaving as Stata 5.0 (even if you have Stata 6.0 or later).
Under version 5, and before that, quotes (" ") were stripped by Stata from arguments to programs defined by ado-files. Suppose that whatever.ado defines command whatever. What whatever sees when you type
whatever mpg weight if substr(make,1,4) == "Chev"
are the arguments
mpg weight if substr(make,1,4) == Chev
Generally, there are two possibilities:
There is a work-around. Create a variable that will have the correct effect.
gen byte Chev = substr(make,1,4) == "Chev" whatever mpg weight if Chev
That is, you keep the string comparison out of sight of whatever and create an indicator variable that is 1 or 0 depending on whether the relation is true or false. Stata commands that are defined in the executable do not suffer from this problem: generate is one such command.
This is a rare example of users being affected by whether a command is defined by an ado-file or as part of the executable. Typically, that is a consideration for programmers only (apart from performance issues, sometimes).
More ambitiously, you could try editing the code in whatever.ado, but even expert Stata programmers might be very wary of doing that because there might be side effects.
This bug was fixed in Stata 6.0, and programs defined in ado-files under version 6.0 or later do not suffer from the same problem.
Learn
Free webinars
NetCourses
Classroom and web training
Organizational training
Video tutorials
Third-party courses
Web resources
Teaching with Stata
© Copyright 1996–2024 StataCorp LLC. All rights reserved.
×
We use cookies to ensure that we give you the best experience on our website—to enhance site navigation, to analyze usage, and to assist in our marketing efforts. By continuing to use our site, you consent to the storing of cookies on your device and agree to delivery of content, including web fonts and JavaScript, from third party web services.
Cookie Settings
Last updated: 16 November 2022
StataCorp LLC (StataCorp) strives to provide our users with exceptional products and services. To do so, we must collect personal information from you. This information is necessary to conduct business with our existing and potential customers. We collect and use this information only where we may legally do so. This policy explains what personal information we collect, how we use it, and what rights you have to that information.
These cookies are essential for our website to function and do not store any personally identifiable information. These cookies cannot be disabled.
This website uses cookies to provide you with a better user experience. A cookie is a small piece of data our website stores on a site visitor's hard drive and accesses each time you visit so we can improve your access to our site, better understand how you use our site, and serve you content that may be of interest to you. For instance, we store a cookie when you log in to our shopping cart so that we can maintain your shopping cart should you not complete checkout. These cookies do not directly store your personal information, but they do support the ability to uniquely identify your internet browser and device.
Please note: Clearing your browser cookies at any time will undo preferences saved here. The option selected here will apply only to the device you are currently using.