Skip to main content

Milind's letter for May is all about Me , er, My

If you check out the Visual FoxPro: May 2006 - Letter from the Editor, Milind refers to the updated CTP documents. Without worrying about the DotNet CTP stuff and the update about Service Pack 2 (note that SP2 will be dealing with some of the stuff they've discovered about Vista), the real cool piece, at least to me, is this little add-on called "My"

As Milind explains it, it essentially contains wrappers for SYS functions and Windows API calls, etc. Why is this a big deal?

I remember a variety of devcons and ER requests for VFP where users would ask for "add a Machine Name function" and the response was "use SYS(0)" or any one of the other SYS functions. SYS was great for functionality but terrible for readability. My makes it a little easier although you have to be used to looking at a lot of "."s.

A lot of code I've seen puts these settings into memory variables for later use. I used to use SYS(0) as my example for using the SUBSTR and ATc function.

lcUserName = SUBSTR(SYS(0),ATC("#",SYS(0))+2)

But now with My, it becomes much easier and I don't really need a variable anymore.

Why bother writing the above when I can use:

IF My.User.UserName="andrew"
...
ENDIF

But My is going to be so much more useable than for things like this. Yeah, it has some stuff like My.Computer.Audio.Play but it also has direct access to the Registry with My.Computer.Registry and lets you retain settings with My.Settings.Add() and My.Settings.Load and Save.

Why bother using AGETFILEVERSION() when you can simply say

My.App.Info.CompanyName and My.App.Info.Version

Yes, if you've been writing code for a while, you likely already have functions for this - for users just starting out ( or for readability with others who may be coming from VB 2005), the My workspace is going to be a lot of fun.

Oh, and did I mention that the help file has a topic about how you can add your own classes to it? Now, THAT Rocks!

Download the feature overview here to get a feel for it. The My spec is actually a help file which makes it even easier to read through and get a feel for.

Comments

wOOdy said…
Hi Andrew, just some hairsplitting detail on your SYS(0) example: a somewhat better approach is:
cUsername = GETWORDNUM(SYS(0),3)

But back to the MY stuff: We will be facing a huge problem: All that My stuff comes bundled within a VCX. Thus using only one tiny MY functionality will suck in the whole My.vcx, which in turn sucks in the whole FFC classes, which in turn suck in all .... Get the picture? As long as there isn't some tool which just extracts the needed resources from any VCX, this will cause lots of troubles.
Andrew MacNeill said…
woody,

Yes - you're right about GETWORDNUM() - good idea!

I agree about the potential size issues with My - which is why it's important that a lot of additional functionality either gets added to it (so that it just becomes so invaluable you can't live with it ) OR someone (who??) builds a tool to do just what you described.


Maybe what we need to is an intelligent "Implements" engine Project hook that creates a specialized class lib that only pulls out what's needed.

Popular posts from this blog

Blogs and RSS come to Microsoft.com

MS has just introduced their portal and it's pretty comprehensive. Nothing quite like learning that some people use AIM instead of MSN messenger, or that there really may be a need for supporting 4 monitors ( Cyrus Complains ) However, it's really a great sign that MS is serious about supporting the blogging community which seems to have um, exploded in size in the past year. Blogs and RSS come to Microsoft.com

Programmers vs. Developers vs. Architects

I received an email this morning from Brandon Savage 's newsletter. Brandon's a PHP guru (works at Mozilla) but his newsletter and books have some great overall perspectives for developers of all languages. However, this last one (What's the difference between developers and architects?) kind of rubs me the wrong way. Either that, or I've just missed the natural inflation of job descriptions. (maybe, it's like the change in terminology between Garbage man and Waste Engineer or Secretary and Office Administrator) So maybe it's just me - but I think there's still a big difference between Programmer, Developer and then of course, architect. The key thing here is that every role has a different perspective and every one of those perspectives has value. The original MSF create roles like Product Manager, Program Manager, Developer, Tester, etc - so every concept may pigeon hole people into different roles. But the statements Brandon makes are often distinction

FoxInCloud Stats

FoxInCloud sent this link a while back about their statistics regarding visits to their site: http://foxincloud.com/blog/2017/12/27/VFP-community-lessons-from-foxincloud-site.html What's interesting here is the breakdown of people. Yes, I think it's understandable that the Fox community is getting older. Another factor is the growth of the mobile and web environments taking over development. These environments really do push people towards the newer non-SQL or free SQL/hosted environments but more towards hosted storage options like Amazon and Google. A tool like FoxInCloud that helps MOVE existing applications to the cloud inherently competes with those environments. But FoxInCloud also allows developers to extend their application further by giving them a starting point using Javascript and the basic CSS (such as Bootstrap). If you're not rebuilding your application from scratch, it's certainly a great step forward. FoxPro VFP