Slashdot Mirror


VCF - A Free BSD Competitor To Trolltech's Qt?

TioHoltzman writes "There's a new 0-6-5 release available of the VCF, aka the Visual Component Framework. This release has a slew of new features, and it looks like it could become a real contender against Trolltech's Qt toolkit. It currently runs on Win32 platforms with an active Mac OS X port underway. There's still lots to do, but it can run some of the samples now on OS X. There are some screenshots here (1), here (2), and here (3)."

26 of 75 comments (clear)

  1. It's not that I'm against advertising... by david.given · · Score: 3, Insightful
    ...but if you're going to post an advertisement, say it's an advertisement! Tio Holtzmann is a direct spokesman for VCF; submitting a story as if it was written by a third party is dishonest and makes the whole editorial process at Slashdot look shabby.

    Well, shabbier.

    At least the submitter is a real user with a history, and wasn't created as a marketing ploy; but would it have been so hard to stick 'Disclaimer: I'm one of the developers!' at the bottom?

    1. Re:It's not that I'm against advertising... by Anonymous Coward · · Score: 3, Funny

      But this is Free (as in Free Beer) advertising! ;-)

    2. Re:It's not that I'm against advertising... by TioHoltzman · · Score: 5, Interesting

      I have tried 3 different times to get this story submitted in one way or the other for the past several months (including one earlier today that got rejected within less than an hour!). They have all been rejected. Several other members of the project have also tried repeatedly to get a submission and those too got rejected. I don't like doing this anymore than you do but it seems that's what it takes to get a submission accepted.

    3. Re:It's not that I'm against advertising... by eraserewind · · Score: 4, Interesting
      I have tried 3 different times to get this story submitted in one way or the other for the past several months (including one earlier today that got rejected within less than an hour!). They have all been rejected. Several other members of the project have also tried repeatedly to get a submission and those too got rejected. I don't like doing this anymore than you do but it seems that's what it takes to get a submission accepted.
      But you know, this isn't Freshmeat. It's a discussion forum. Maybe the fact that is was rejected 3 times should tell you something.

      The point release notifications of famous apps like Mozilla are bad enough, but some library we haven't heard of before that does the same as a bunch of other libraries out there?

      If the news that Mozilla or OpenOffice or something like that was switching to VCF then it might be newsworthy.
    4. Re:It's not that I'm against advertising... by Senjutsu · · Score: 3, Insightful

      Perhaps, but when every single developer who runs into the project keeps asking why this is not getting more press and being written up on slashdot, maybe that says something to?

      It does. It says:

      Keep improving your project, and eventually it will get noticed, used, and become popular enough that some impartial third party will become excited enough to submit a story about something related to it (Ask Slashdot: Why isn't VCF more well known?, perhaps),

      On the other hand, what it doesn't say is:

      Submit a story to slashdot pretending you aren't the lead developer while the project is still in its early and butt ugly stages and has no compelling advantage over any of its competitors, thereby irritating and alienating the very audience that might otherwise have cared about it. You want to advertise your own project, submit it to Freshmeat again, FFS. It's not windows only anymore.

      If the only person who cares enough to submit something about your project is you, be up front about it. Don't try to con people into believing otherwise. This is hella lame.

    5. Re:It's not that I'm against advertising... by asdfghjklqwertyuiop · · Score: 2, Insightful

      I don't like doing this anymore than you do but it seems that's what it takes to get a submission accepted.


      When all else fails, just lie...
  2. But will it continue to run on Win32 by Marxist+Hacker+42 · · Score: 4, Interesting

    Past Tomorrow?

    I hope it's just me, and the amount of work I've been doing lately on this subject- but XP with SP2 on any AMD processor won't even allow the Windows CE VM to execute in debug mode. What chance does a third party language/compiler/debugger have?

    --
    SJW: a person who perceives an injustice, and while correcting it, commits a greater injustice.
  3. Re:Frameworks arent platform specific by jhunsake · · Score: 4, Informative

    Notice the space between "Free" and "BSD"? Notice that "To" is capitalized?

    Ok, then you should be smart enough to figure out that the title is really

    "VCF - A free BSD Competitor to Trolltech's Qt?"

  4. Missing a couple things? by JabberWokky · · Score: 4, Interesting
    Stuff like the application scripting language, data abstraction, relational database libraries, accelerated 3d, etc. Qt is a bit more than just a visual toolkit at this point, having pulled into it and made platform independant many of the ideas implemented in KDE.

    --
    Evan

    --
    "$30 for the One True Ring. $10 each additional ring!" -- JRR "Bob" Tolkien
    1. Re:Missing a couple things? by EvilIdler · · Score: 2, Informative

      wxWidgets has all those things Qt has, too.
      (wxwidgets.org)

  5. What am I missing? by I_Love_Pocky! · · Score: 3, Interesting

    Why is this just a competitor to QT? Is there something specific about it that makes it directly competitive with QT? Isn't it a windowing framework, making it competitive with GTK and others as well?

    1. Re:What am I missing? by SewersOfRivendell · · Score: 3, Informative
      Why is this just a competitor to QT? Is there something specific about it that makes it directly competitive with QT? Isn't it a windowing framework, making it competitive with GTK and others as well?

      GTK and most others don't compile Mac OS X native apps, and GTK isn't written in C++. GTK 1.4 was ported for use with earlier versions of the GIMP, but no one's bothered to port a modern version, it would appear. Most frameworks don't bother with a Mac port. So Qt can currently use native (or pseudo-native, in the OS X case) controls on Windows, Mac, and Linux, and VCF would be a new competitor in that space. wxWindows probably already competes there, but the results I've seen from wxWindows apps have been pretty mixed, and the source code isn't pretty, being infested with win32 (pre-OO) notions of how event handling should work.

    2. Re:What am I missing? by JabberWokky · · Score: 4, Insightful
      Yes, but Qt isn't a GUI toolkit, it is an application development framework and language extension (Database abstraction, application scripting, Signals and Slots, the foreach loop, etc). All I see here is a GUI toolkit. GUI widgets and layout comprise only a small part of what Qt is.

      --
      Evan

      --
      "$30 for the One True Ring. $10 each additional ring!" -- JRR "Bob" Tolkien
    3. Re:What am I missing? by stienman · · Score: 3, Informative
      Currently QT is really the only substantial cross platform framework that really does well on Windows as well as Linux/bsd/etc.

      However, QT is licensed such that Windows work cannot really be done for free. It may be open, but it certianly isn't free. This isn't a bad thing, but it is limiting.

      VCF is not only free and open, but it is licensed under the BSD license, meaning that it can (and likely will) gain a much larger audience than QT simply because it can do (or will do) everything QT does, but without cost. One can even modify the code without releasing their proprietary changes which is a big plus for many companies. One of the reasons, I suspect, Apple took from FreeBSD instead of Linux when they needed to Unix-ify their OS was because of the freedom it gave them. (probably also because BSD had already fought its legal battles and was known to be copyright safe)

      GTK and others really don't support windows and linux together as well as QT does.

      From the Features:
      The Visual Component Framework is a C++ application framework that offers a modern, clean, C++ architecture and is designed to be cross platform. The core framework is divided into three major libraries, the FoundationKit, the GraphicsKit, and the ApplicationKit. The FoundationKit provides basic services such as file access, streams, threads and synchronization primitives, and advanced RTTI features. The GraphicsKit provides a nice set of graphics classes for working with both image and vector graphics, and has built in support for the Anti-Grain Graphics library, as well as image loading services to facilitate loading various graphics formats. Finally, the ApplicationKit provides a rich set of GUI controls, use of the Model-View-Control pattern, property and component editors, undo/redo support, drag-and-drop, and clipboard services, application resources, and UI metrics and policy managers.

      To facilitate cross platform functionality the VCF is is built using a system of peer interfaces that abstract away the various platform specific calls, with each peer tackling a specific service, such as as threading, file handling, windowing system controls, and so forth. These peer classes are also exposed, and can be used to get access to the lower level OS handles or primitives that they wrap, allowing the developer to write platform specific code if the need arises.

      Finally, the VCF is flexible. While it is certainly designed to be a standalone application framework, it also aims, as much as possible, to cooperate with existing toolkits and/or frameworks. For example, if you have an MFC application, you can easily use just the GraphicsKit to make use of the more advanced features in it, as opposed to using the MFC CDC, CBrush, and CPen drawing classes.


      -Adam
    4. Re:What am I missing? by TioHoltzman · · Score: 5, Informative

      In addition to the GUI stuff the VCF provides:

      • Thread support with Mutexts, Conditions, and Semaphores
      • File and file searching
      • Streams
      • Locale and Unicode support
      • Text codes
      • String messages for localizing your app
      • Registry wrapper for app prefs
      • A full fledged reflection API that is conceptually similar to the Java Reflection API. This allows for dynamically creating an object instance from only a class name, interrogating the instance for methods, properties, events, and interfances. The overhead for this is pretty minimal. You do have to register the class but this is pretty easy to do and doesn't require a separate pre-processor step like Qt's MOC does.
      • A event system that is very similar to delegates in .NET and extremely easy to use.
      • Simple XML parsing support
      All of this is plus, unlike Qt or WxWidgets, or FOX or whatever, the framework is broken into smaller pieces as opposed to one monolithic library. All of the above features are available in the FoundationKit and completely suitable for console/server developement, without any GUI baggage.

      Application scripting can be achieved by using the VCF's Reflection API's to wrap a script engine. For example, in one app I wrote I used the Mozilla JavaScript engine and made a VCF wrapper that simply hooked into the VCF's ClassRegistry. Thus any class that you registered with the VCF's runtime was also available for scripting with the JavaScript engine. Took about 200 lines of code. From what I have seen I would expect a Python wrapper to be equally easy to write.

    5. Re:What am I missing? by e8johan · · Score: 2, Insightful

      The product seems to be missing database support. That is pretty much a requirement to compete with Qt. Many, if not most, custom applications used in businesses today use databases in some way.

    6. Re:What am I missing? by JabberWokky · · Score: 3, Interesting
      Yep - it has all that, which is why I didn't list them in my features of Qt that this dosen't have. Basically, it has all the stuff that is necessary to implement a GUI, and nothing else.

      unlike Qt or WxWidgets, or FOX or whatever, the framework is broken into smaller pieces as opposed to one monolithic library

      Same goes for Qt; the framework is broken out. Some of the enterprise features are sold as options.

      All of the above features are available in the FoundationKit and completely suitable for console/server developement, without any GUI baggage.

      Ditto for Qt.

      As for your last point, Qt already has scripting built in with secure access as opposed to a wrapper for Reflection. You can use several languages as well.

      I'm not saying that this isn't good... I'm just saying that there's quite a bit more to Qt than what is available here and that Qt is quite a bit down the development curve.

      --
      Evan "but then, I'm a procedural kinda guy anyway..."

      --
      "$30 for the One True Ring. $10 each additional ring!" -- JRR "Bob" Tolkien
    7. Re:What am I missing? by ndogg · · Score: 3, Informative

      Just to clear something up:
      So Qt can currently use native (or pseudo-native, in the OS X case)

      Pseudo-native? It is native. Emulating it would be too cumbersome.

      --
      // file: mice.h
      #include "frickin_lasers.h"
    8. Re:What am I missing? by TioHoltzman · · Score: 2, Informative

      To the best of my knowledge, Qt is the only other C++ framework out there that offers the range of runtime dynamic introspection that the VCF does. The VCF (and Qt as well) allows you to get all sorts of meta information about a particular C++ instance, such as the class name, class UUID, interfaces implemented by the instance, methods of the instance, properties, and events. Methods can be invoked dynamically at runtime, and properties can be queried or modified as well.

      By allowing for all of this the VCF gives you the potential to build a full fledged set of components on top of this, just like Borland's Delphi or Java (or Cocoa for that matter), with support for ComponentEditors and PropertyEditors. Because all of this can be queried at runtime, you can build a really kickass GUI builder, again just like Delphi or Cocoa's InterfaceBuilder. Qt can also support this (though they do it a bit differently I believe, but it's pretty close). WxWidgets, FOX, GTK, et al, don't have the features built in to really support anything like this. QTK has a sort of OO like property system but it's extremely hacky and cumbersome to use (IMHO). Qt and the VCF, make this easier because of C++.

      Whereas Qt requires a separate preprocessor step, the MOC tool, a developer using the VCF is able to supply this information all in regular C++ and through the usage of macros (icky, but hey, life's not perfect).

      Here's some more info on the reflection API's in the VCF:
      RTTI docs

  6. Re:Frameworks arent platform specific by winfx · · Score: 2, Insightful

    I cannot understand how a free GUI, can become a standard on win32 when Windows next version are converting to Avalon (winfx) abandoning win32 and when is based on C++ RTTI (only C++ can take advantage of it) when Windows present and future is .NET and C#.

  7. Isn't this just WxWindows all over again? by FFFish · · Score: 4, Informative

    And doesn't Wx have the lead by, oooh, must be about five years?

    Of course, the biggest flaw with Wx is that its lead developer doesn't have the cojones to submit a Slashdot story as if he were an impartial user...

    --

    --
    Don't like it? Respond with words, not karma.
  8. Re:Frameworks arent platform specific by aled · · Score: 2, Funny

    The majority of Slashdot readers are delusional.

    No, we are not!... my precious... aren't we?

    --

    "I think this line is mostly filler"
  9. Re:All hat and no cattle. by jhunsake · · Score: 3, Insightful

    Don't listen to these assholes. If I still programmed in C++, I'd definately consider using VCF.

  10. Documentation by e8johan · · Score: 3, Informative

    I believe that one part of Qt's success is the great documentation. This: http://vcf.sourceforge.net/docs/ref_manual/ch03s04 .html does not look like great docs to me (the page has only titles, no text).

    1. Re:Documentation by Brandybuck · · Score: 2, Interesting

      So why the hell can't they document as they write the code? Have they not heard of Doxygen? Oh wait, Doxygen uses Qt, so they can't do that...

      --
      Don't blame me, I didn't vote for either of them!