Code-import en code-generatie
&umbrello; is een ¨ modelling gereedschap en als zodanig is zijn voornaamste doel u te helpen bij de analyse en het ontwerp van uw systemen. Echter, om de overgang van uw ontwerp naar uw implementatie te maken, kunt u met &umbrello; broncode genereren in verschillende programmeertalen om u van start te laten gaan. Ook, als u ¨ wilt gaan toepassen in een reeds gestart C++ project, kan &umbrello; u helpen bij het maken van een model van uw systeem op basis van uw broncode door deze te analyseren en de daarin gevonden klassen te importeren.
Code-generatie
&umbrello; kan broncode genereren voor talrijke programmeertalen op basis van uw ¨ model om u te helpen van start te gaan met de implementatie van uw project. De gegenereerde code bestaat uit klasse declaraties, met hun methoden en attributen, dus u kunt de blanke ruimte invullen
door de functionaliteit van uw klassen-operaties te verschaffen.
&umbrello; 1.2 komt met code-generatie ondersteuning voor ActionScript, Ada, C++, CORBA IDL, &Java;, JavaScript, PHP, Perl, Python, SQL en XMLSchema.
Code genereren
Om code te kunnen genereren met &umbrello;, dient u eerst een model te maken, of er een te laden, met minimaal één klasse erin. Als u gereed bent om te beginnen met het schrijven van enigerlei code, dan selecteert u de Code Generatie Wizard menukeuze in het Code menu om een assistent te starten die u door het code-generatie proces zal loodsen.
De eerste stap is het selecteren van de klassen waarvoor u broncode wilt genereren. Standaard worden alle klassen van uw model geselecteerd, selected, en u kunt diegene, waarvoor u geen code wilt genereren, verwijderen, door ze naar lijst aan de linkerkant te verplaatsen.
In de volgende stap van de assistent kunt u de parameters wijzigen welke de codegenerator gebruikt bij het schrijven van uw code. De volgende keuzemogelijkheden zijn beschikbaar:
Codegeneratie keuzemogelijkheden
Keuzemogelijkheden voor de codegeneratie in &umbrello;
Keuzemogelijkheden voor de codegeneratie in &umbrello;
Generatie keuzemogelijkheden
Code breedvoerigheid
De keuzemogelijkheid Schrijf documentatie commentaar zelfs indien leeg instrueert de codegenerator om commentaar van de vorm /** blah */ te schrijven, zelfs als de commentaarblokken leeg zijn. Als u documentatie heeft toegevoegd aan uw klassen, methoden en attibuten in uw model, dan zal de codegenerator deze commentaren als Doxygen documentatie wegschrijven, ongeacht wat u daar formuleerde, maar als u deze keuzemogelijkheid selecteert dan zal &umbrello; commentaarblokken schrijven voor alle klasses, methoden en attributen, zelfs wanneer er geen documentatie in het model is, in welk geval u uw klassen later dient te documenteren, rechtstreeks in de broncode.
Schrijf commentaar voor secties zelfs indien sectie leeg is zorgt ervoor dat &umbrello; commentaar schrijf in de broncode om de verschillende secties van en klasse af te bakenen. Bijvoorbeeld public methoden
of Attributen
voor de corresponderende sections. Als u deze keuzemogelijkheid selecteert, dan zal &umbrello; commentaar wegschrijven voor alle klasse-secties ook als de sectie leeg is. Bijvoorbeeld, het zou commentaar met de tekst protected methoden
wegschrijven ook als er geen protected methoden in uw klasse zijn.
Mappen
Schrijf alle gegenereerde files naar map. Hier dient u de map te selecteren waarin &umbrello; de gegenereerde bronnen van u moet plaatsen.
De Sluit headerfiles in uit map keuzemogelijkheid geeft u de mogelijkheid om een header aan het begin van iedere gegenereerde file toe te voegen. Headerfiles kunnen auteursrecht of licentie informatie bevatten maar ook variabelen die op het moment van genereren geëvalueerd worden. U kunt eens kijken naar naar de sjabloon headerfiles zoals die met &umbrello; meegeleverd worden om te zien hoe dit soort variabelen gebruikt moeten worden om uw naam en of de huidige datum te vervangen ten tijde van het genereren.
Overschrijvings protocol
Deze keuzemogelijkheid vertelt tegen &umbrello; wat het moet doen als het bestand dat het wil maken, reeds in de bestemmingsmap voorkomt. &umbrello; kan bestaande bestanden niet wijzigen, derhalve moet u een keuze maken uit: of het bestaande bestand overschijven, of het genereren van dat ene aparte bestand overslaan, of &umbrello; een andere bestandsnaam laten kiezen.Als u kiest voor de mogelijkheid van een andere bestandsnaam, dan zal &umbrello; de bestandsnaam van een achtervoegsel voorzien.
Taal
&umbrello; zal standaard code genereren in de taal die u als actieve taal heeft geselecteerd, echter met de codegenererings-assistent heeft u de keuzemogelijkheid om dit naar een andere taal te veranderen.
Genererings-assistent genereren
De derde en laatste stap van de assistent toont de status van het codegenererings proces. U hoeft alleen nog maar op de knop genereren te klikken om de klassen voor u te laten wegschrijven.
Merk op dat de keuzemogelijkheden die u selecteert in de codegenererings-assistent alleen gelden voor de huidige generering. Wanneer u de assistent een volgende keer gebruikt, dan moet u alle keuzemogelijkheden opnieuw selecteren (de map voor uw headers, overschrijvings protocol, enz.). U kunt de standaarden die &umbrello; aamhoudt, instellen in de sectie code genereren van de &umbrello; settings, beschikbaar in Instellingen&umbrello; instellen...
Als u uw codegenererings keuzemogelijkheden op de juiste waarden heeft ingesteld, en u zomaar enige code wilt genereren zonder door de assistent heen te moeten gaan, dan selecteert u het Genereer alle code in het code-menu. Dit zal code genereren voor alle klassen in uw model met gebruikmaking van de huidige instellingen (inclusief uitvoermap en overschrijvings-protocol, dus pas op met het gebruik ervan).
Code import
&umbrello; kan broncode importeren vanuit uw bestaande projecten om u te helpen met het construeren van een model voor uw systemen. &umbrello; 1.2 ondersteunt alleen C++ broncode, echter andere talen zouden beschikbaar moeten komen in toekomstige versies.
Om klasses in uw model te importeren, selecteert u de menukeuze Klassen importeren... in het Code menu. Selecteer in de bestandsdialoog de bestanden die de C++ klasse-declaraties bevatten en druk op OK. De klasses worden nu geïmporteerd u zult ze aantreffen als deel van uw model in de boomstructuur. Merk op dat &umbrello; geen enkel soort diagram aanmaakt om uw klassen te tonen, ze worden alleen in uw model geïmporteerd opdat u ze naderhand in welk diagram dan ook, kunt gebruiken.
Code import
Menu om broncode te importeren in &umbrello;
Menu om broncode te importeren in &umbrello;