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)."

18 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.

  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
  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 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
    6. 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"
  6. 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.
  7. 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.

  8. 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).