Open Source Design Tools?
mbogosian asks: "Recently, my broadened responsibilities have me doing some database design and modeling, and I'm happy for the new knowledge and experience, but I'm a bit frustrated about the tool selection. I know most of us have had plenty of experience with at least a handful of all the wonderful Open Source development tools out there (like GCC, GNU Make, Subversion , and Perl to name a few). My question is this: where are OpenSource design tools? I've tried what I could find on SourceForge, but (as usual?) most of the projects that sounded promising were either still in the planning stages or seemed abandoned. Of course something which allowed be to create nifty class charts and output them to UML and/or SQL would be really cool, but I've yet to find something that works (especially in Linux). What are your favorite Open Source design tools and what do you like about them?"
Poseidon for UML Community Edition from Gentleware is a really nice modeling and reverse-engineering tool. It's Java-based (a *tad* slow on startup) and has great support.
Mind the gap...
Dia and Umbrello are the two I found to be some use. ArgoUML, a java program, was really unwieldy, and I don't recommend it. If you're just looking to draw a nice diagram (for presentation purposes), rather than use it in the design process, I found that actually OpenOffice's Drawing program was excellent for the purpose, with lots of arrow/line types (curved, straight, etc).
Daniel
Carpe Diem
I can strongly suggest using Dia in conjunction with tedia2sql. You can do the graphical design in Dia and then convert the result to SQL for various databases (Oracle/MySQL/PostgreSQL/...). ...
It is really fast and stable, it supports tables with indexes, primary keys, foreign keys,
ArgoUML is a Java based (and biased) UML development toolkit - well worth investigating
Tigris itself contains many other open source software engineering tools for design, construction, testing, deployment and more
Synopsis:
Tigris.org Community Scope
Tigris.org is a mid-sized open source community focused on building better tools for collaborative software development.
You will not find thousands of unrelated projects here: every project fits into the Tigris vision.
You will not find dead projects here: every project is welcomed into the community with a commitment to see it through and active developers cycle among related projects.
Tigris.org is hosted by CollabNet, but the Tigris vision is one for the entire open source movement and one that has attracted senior open source developers from many organizations.
My question is this: where are OpenSource design tools? I've tried what I could find on SourceForge, but (as usual?) most of the projects that sounded promising were either still in the planning stages or seemed abandoned. Of course something which allowed be to create nifty class charts and output them to UML and/or SQL would be really cool, but I've yet to find something that works (especially in Linux). What are your favorite Open Source design tools and what do you like about them?"
It's a matter of using the right tool for the job. Example: the Linux kernel developers use proprietary BitKeeper rather than free CVS, because BitKeeper is simply a better tool. Using a free tool just because it is free is a poor decision, because it will cost you more in the long term in lost productivity. In this case, there are no open source design tools because there are no open source applications that have complex schemas (say 100 tables or more). Plus there is an unfortunate attitude that still permeates open source "real men start coding, only corporate minions do UML".
If you need a good tool, try Oracle Designer or Together/J, or since IBM are Linux's new best friend, you might want to look at Rose. I guess if you are cheap you could use Visio.
You may want to try Data Architect from The Kompany for database modelling.
I do not have much experience using it, but the screenshots look very slick (a good judge for open source apps since the UI is generally the weakest link!)
The listed features include:
* Workspace/Project oriented environment
* ERD centric data modelling
* model panner ("birds eye view")
* quick find and naviagtion from output window
* model validation
* full documentation capabilities
* integrated Advanced SQL Editor with syntax highlighting
* SQL Project - a multi-platform (Windows, Mac OS X, Linux), multi-database, integrated development environment
* save/load SQL sessions
* integrated ODBC
* multi-platform (Linux, MS Windows and soon Mac OS X)
* multi-database (ODBC, MySQL, PostgreSQL, DB2 and InterBase/FireBird coming soon)
* open file format (XML)
* DBMS specific features such as data types and SQL syntax
* reverse engineer existing databases
* generate create-scripts
* print model
* print data dictionary
* liberal use of tool-tips to help Users
* integrated Team Diagram> (general purpose diagramming)
* supports table inheritance
* supports; table, view, domain, sequence, procedure
Supported databases are:
* generic using ODBC
* MySQL
* PostgreSQL
* DB2
* InterBase/FireBird (in testing)
It is not free as in beer, but the license agreement seems to indicate that you will get the source. It is reasonably priced at $39.95 for the download version and you will be supporting a great company.
And don't be surprised if you get an email back from the president of the company, Shawn Gordon. I sent an email yesterday to the support address and received a reply from him within a few minutes.
You may also want to look at their BlackAdder IDE. Screenshots here.
Regards,
Adi Gadwale.
Hey, to my knowledge, there isn't an open-source tool that'll do what you want. You might, however, just consider shelling out the cash for a program such as Embarcadero's Describe. Check it out, and see if it fits your needs.
Oh, and it uses Perl as a scripting language, so you can really customize it to match your design flow wherever you are. One of our coders modified an existing script to make it do some useful things, like interact with the GUI, and (of course) the core of the program.
One of the better mods someone around here came up with is one that lets it trundle over source code, and reverse-engineer the UML for you, if you're working off of an existing code base.
Take a look. They offer downloads for trial purposes.
Michael C. Hollinger
I tried Dia some time ago and found it very frustating to use, with most of built in objects being too restrictive and lacking enough variety of connection points to terminate lines and arrows.
For line diagrams (e.g. for documenting 3D graphics algorithms), I've moved on to qcad, which is a 2D CAD package.
For OO design, you can try doing this backwards : prototype the interfaces and classes and run doxygen (with dot) to generate inheritance and collaboration diagrams or XML output for post-processing. This probably fits in more with an extreme programming prototype/refactor style methodology than a complete up-front design methodology.
For state diagrams, I've had some success using dot on its own.
Using doxygen and dot has the significant additional feature that the files you edit are all plain-text files, so you can use your existing source revision control system (e.g. CVS)
Even with these packages however, I usually still find a pen and paper (or a white-board or blackboard if available) the easiest and fastest option for sketching out an initial design, or during discussions of various design alternatives with colleagues.
Try eclipse from (http://wwww.eclipse.org) which is opensource along with Omondo Plugin from (http://www.omondo.com) free for developing, not open source.
. jsp
u gins.jsp? category=UML
More plugin for eclipse are listed here
http://eclipse-plugins.2y.net/eclipse/index
for other UML Plugins
http://eclipse-plugins.2y.net/eclipse/pl
Abandoned projects on Sourceforge? I don't believe it.
Since Open Source software is.. evolutionary... Maybe what you are finding is how little the design tools are needed. Granted the people who work on Open Source software love to WRITE software, and not formally design it. The design evolves on its own, so why try and manage it closely. It will take care of itself. See Linus rants on this. He believes he makes design decisions by picking and choosing clumps of other peoples work.
Its not surprising to me that there are no "design" tools.. They just aren't that important or needed in writing Open Source software.
My question is this: where are OpenSource design tools?
The best high-level design tools for UML, database schemas, etc. are still proprietary. This is also the reason I hesitate to use such tools in the first place. For example, how does a binary project file get effectively version-controlled? How can it be shared with people who haven't blown $1,500 for SuperDesignToolXYZ?
I've also seen thousands of dollars blown on design tools, when the project is so small, anyway, that plain text files would have sufficed. Or, better, actually documenting the class definitions in a Java or C++ project.
Don't forget that design tools also have their own built-in and distracting learning curve. It is easy to waste time poking around in a tool without actually accomplishing real work. If a company is going to invest in the cost of a design tool, at least send the team to a week of training.
In short, design tools are always a mixed blessing and should be viewed skeptically.
Healthcare article at Kuro5hin
If you're asking about CASE tools, I'd recommend that you stay away from them. While CASE tools can be useful for managing larger database schemas, I've found that--for small and mid-sized schemas (dozens of tables)--they tend to hinder more than help. They add a layer of abstraction between you and your design, one which prevents you from really getting into the guts of your design. Personally, I always use a whiteboard to sketch out my design and write all of my SQL from scratch. May be old-fashioned, but I've never found anything that works better. When I'm done designing a schema, I know every column intimately and I have a reason and justification for every decision. CASE tools take those decisions out of your hands. If you want to use CASE tools to manage (rather than design) your schema, you can always import the completed design into your tool of choice.
When it comes to database design, a nice large whiteboard is your best friend.
Dome I'm just using it for DFD/ERD but it handles most diagrams I've ever heard of.
Just happened to see this on Freshmeat today:
http://www.jameswells.net/KlassModeler/
Looks like it might be appropriate, OSS and GPLed
Umbrello
/*Why is there a prnguin on my screen?!*/
The lunatic is in my head
without a doubt, the all around best ever tool for almost anything is a pad of graph paper.
I grew up with graph paper. I simply think better with a pencil and a pad of graph paper. I've always had a pad and my clipboard since I was 8 years old (same board, too) and I'm 32 now.
Be it mechanical, electronic, or software, I always start with graph paper.
I've tried using software for drawing diagrams and such, but it just gets in the way. Sure, when you want to make a published version of documentation, then you need it. But for actual design and refinement of your thought patterns, it just can't be beat.
-- Senior Software Engineer, Attorney appearance services, locallawyerapp.com.
I've been running Sparx Systems Enterprise Architect for about 1.5yrs on Windows. Prior to that, I was running Rational Rose - but got sick of paying out the ass for upgrades each year. EA, as it's known, rivals Rose in many ways and costs less than $200/seat. I absolutely love it. It doesn't entirely answer your question; So recently, I discovered that it works flawlessly on Linux via CrossOver Office (assuming you copy over MS Sans Serif from Windows). Check it out (there's an unlimited 30 day trial version) or send me a private message.
I called the company that makes ErWin (I think it is C.A., but I am not sure and too damn lazy to look it up...sorry...but that's the breaks) If enough people call and request a Linux version, maybe they will port their software. Sure, you will probably have to pay for it, but at least there will be commercial OOA/D ERD tools available. I have been calling Quest (SQL Navigator and TOAD) about a Linux port. It is on their agenda, but not until 2004. Once these "Business" tools become available, then Linux may be more accepted by Monkey-Assed MBAs. Sorry, but I have tried to use Dia. It sucks when you are trying to ERD a schema with more than two entities. OpenOffice is much better, but lacks the "Shapes" and it does not generate code. A plug-in for Eclise would be GREAT. Too bad there are not any GREAT once out there. Too bad I have to support a family, otherwise I might just build my own plug-in. (The boss would rather pay me to solve their problems, not build tools to help me solve their problems)