object-oriented and procedural
programming language
produced by Microsoft
. It is derived from FoxPro
(originally known as FoxBASE) which was developed by Fox Software beginning in 1984. Fox Technologies merged with Microsoft in 1992, after which the software acquired further features and the prefix "Visual". The last version of FoxPro (2.6)
worked under Mac OS
, DOS
, Windows
, and Unix
: Visual FoxPro 3.0, the first "Visual" version, reduced platform support to only Mac and Windows, and later versions were Windows-only. The current version of Visual FoxPro is COM
-based and Microsoft has stated that they do not intend to create a Microsoft .NET version.
FoxPro originated as a member of the class of languages commonly referred to as "xBase"
languages, which have syntax based on the dBase
programming language. Other members of the xBase language family include Clipper
and Recital. (A history of the early years of xBase can be found in the dBase article.)
Visual FoxPro, commonly abbreviated as VFP, is tightly integrated with its own relational database engine, which extends FoxPro's xBase capabilities to support SQL
query and data manipulation. Unlike most database management systems, Visual FoxPro is a full-featured, dynamic programming language
that does not require the use of an additional general-purpose programming environment. It can be used to write not just traditional "fat client
" applications, but also middleware
and web application
s.
Recent history
In late 2002, it was demonstrated that Visual FoxPro can run on Linuxunder the Wine
Windows compatibility suite. In 2003, this led to complaints by Microsoft: it was claimed that the deployment of runtime FoxPro code on non-Windows machines violates the End User License Agreement.
In December 2005, VFP broke into the top 20 on Tiobe index
for the first time. In March 2007 it was at position 19, making it a "B" language. As of August, 2010, VFP (combined with xBase) is at position 25.
In March 2007, Microsoft announced that there will be no VFP 10, thus making VFP9 (released to manufacturing on December 17, 2004) the last commercial VFP release from Microsoft. The support of Version 9 is ongoing with service packs that were released December 8, 2005 and October 11, 2007.
At the time of the end of life announcement, work on the next release codenamed Sedna (named after a recently discovered dwarf planet
) which was built on top of the VFP9 codebase had already begun. "Sedna" is a set of add-ons to VFP 9.0 of xBase components to support a number of interoperability scenarios with various Microsoft technologies including SQL Server
2005, .NET Framework
, Windows Vista, Office 2007, Windows Search and Team Foundation Server
(TFS). Microsoft released Sedna under the Shared source
license on the CodePlex site. Microsoft has clarified that the VFP core will still remain closed source. Sedna was released on January 25, 2008. As of March 2008, all xBase components of the VFP 9 SP2 (including Sedna) were available for community-development on CodePlex.
In late March 2007 a grassroots
campaign was started by the Spanish-speaking FoxPro community at MasFoxPro ("MoreFoxPro" in English
) to sign a petition to Microsoft to continue updating Visual FoxPro or release it to the community as Open Source
. On April 3, 2007 the movement was noted by the technical press
Also on April 3, 2007 Microsoft responded to the petitioner's requests with this statement from Alan Griver:
"We're very aware of the FoxPro community and that played a large part in what we announced on March 13th. It's never an easy decision to announce that we're not going to release another version of a product and it's one that we consider very carefully.
"We're not announcing the end of FoxPro: Obviously, FoxPro applications will continue to work. By some of our internal estimates, there are more applications running in FoxPro 2.6 than there are in VFP and FoxPro 2.6 hasn't been supported in many years. Visual FoxPro 9 will be supported by Microsoft through 2015.
"For Microsoft to continue to evolve the FoxPro base, we would need to look at creating a 64-bit development environment and that would involve an almost complete rewrite of the core product. We've also invested in creating a scalable database with SQL Server, including the freely available SQL Server Express Edition. As far as forming a partnership with a third-party is concerned, we've heard from a number of large FoxPro customers that this would make it impossible for them to continue to use FoxPro since it would no longer be from an approved vendor. We felt that putting the environment into open source on CodePlex, which balances the needs of both the community and the large customers, was the best path forward."
Operating system compatibility
Version | VFP 3.0 | VFP 5.0 | VFP 6.0 | VFP 7.0 | VFP 8.0 | VFP 9.0 |
---|---|---|---|---|---|---|
Windows 3.x | Yes | No | No | No | No | No |
Windows NT 4.0 | Yes | Yes | Yes | Yes | No | No |
Windows 95 | Yes | Yes | Yes | Runtime only | No | No |
Windows 98 | Yes | Yes | Yes | Yes | Runtime only | Runtime only |
Windows Me | Yes | Yes | Yes | Yes | Runtime only | Runtime only |
Windows 2000 | Yes | Yes | Yes | Yes | Yes | Yes |
Windows XP | Yes | Yes | Yes | Yes | Yes | Yes |
Windows Server 2003 | ? | ? | Yes | Yes | Yes | Yes |
Windows Vista | Compatibility Mode | Yes | Yes | Yes | Yes | Yes |
Windows 7 | Yes | No | Yes | Yes | Yes | Yes |
Information on executable files
Version | VERSION returns | EXE Size | EXE Date | DLL Size | DLL Name |
---|---|---|---|---|---|
VFP 9 SP2 with Hotfixes | Visual FoxPro 09.00.0000.7423 for Windows | 5,648 kb | April 3, 2009 | 4,624 kb | VFP9R.DLL |
VFP 9 SP2 | Visual FoxPro 09.00.0000.5721 for Windows | 5,648 kb | September 21, 2007 | 4,624 kb | VFP9R.DLL |
VFP 9 | Visual FoxPro 09.00.0000.2412 for Windows | 5,620 kb | December 13, 2004 | 4,600 kb | VFP9R.DLL |
VFP 8 | Visual FoxPro 08.00.0000.3117 for Windows | 5,236 kb | September 25, 2003 | 4,200 kb | VFP8R.DLL |
VFP 7 | Visual FoxPro 07.00.0000.9465 for Windows | 4,260 kb | January 4, 2002 | 3,344 kb | VFP7R.DLL |
VFP 6 | Visual FoxPro 06.00.8961.00 for Windows | 4,091 kb | August 18, 2000 | 3,295 kb | VFP6R.DLL |
VFP 5 | Visual FoxPro 5.0.0.415 for Windows | 4,065 kb | January 24, 1997 | 3,148 kb | VFP500.DLL |
VFP 3 | Visual FoxPro 03.00.00.0711 for Windows | 4,374 kb | December 16, 1995 | 3,657 kb | VFP300.ESL |
FPW 2.6a | FoxPro 2.6a for Windows | 2,444 kb | September 28, 1994 | 2,946 kb | FOXW2600.ESL |
Code samples
The FoxPro language contains commands quite similar to other programming languages such as Basic.Loops include do, if, while, for, else commands in a usage easily understood by anyone familiar with other programming languages.
Commands take the form of "command" and "endcommand"
Some basic syntax samples:
The language also has extensive database manipulation and indexing commands.
The "help" index of commands in VFP 9 has several hundred commands and functions described.
The examples below show how to code the creation and indexing of tables, however VFP has table and database builder screens which create the tables and indexes without making you write code.
Hello World example:
Object
Data handling
ODBC access using SQL passthrough
Beta code names
- VFP 3 - TazTasmanian Devil (Looney Tunes)The Tasmanian Devil, often referred to as Taz, is an animated cartoon character featured in the Warner Bros. Looney Tunes series of cartoons. The character appeared in only five shorts before Warner Bros...
- VFP 5 - RoadRunner
- VFP 6 - TahoeLake TahoeLake Tahoe is a large freshwater lake in the Sierra Nevada of the United States. At a surface elevation of , it is located along the border between California and Nevada, west of Carson City. Lake Tahoe is the largest alpine lake in North America. Its depth is , making it the USA's second-deepest...
- VFP 7 - SedonaSedona, ArizonaSedona is a city that straddles the county line between Coconino and Yavapai counties in the northern Verde Valley region of the U.S. state of Arizona...
- VFP 8 - ToledoToledo, OhioToledo is the fourth most populous city in the U.S. state of Ohio and is the county seat of Lucas County. Toledo is in northwest Ohio, on the western end of Lake Erie, and borders the State of Michigan...
- VFP 9 - EuropaEuropa (moon)Europa Slightly smaller than Earth's Moon, Europa is primarily made of silicate rock and probably has an iron core. It has a tenuous atmosphere composed primarily of oxygen. Its surface is composed of ice and is one of the smoothest in the Solar System. This surface is striated by cracks and...
- VFP Next - Sedna90377 Sedna90377 Sedna is a trans-Neptunian object discovered in 2003, which was about three times as far from the Sun as Neptune. For most of its orbit it is even further from the Sun, with its aphelion estimated at 960 astronomical units , making it one of the most distant known objects in the Solar System...
Microsoft pages
- Main Visual FoxPro Microsoft page
- MSDN FoxPro support board
- VFP's online help
- Microsoft VFP 9 support
- Visual FoxPro Downloads page
Other pages
- Visual FoxPro Wiki A repository of FoxPro information (written in VFP)
- A site devoted to the history of FoxPro
- VFPx A Visual FoxPro Community effort to create open source add-ons for VFP 9.0