![]() |
Re: Sinnvolle Ordnerstruktur für mehrere Projekte in Subvers
Immer ein komplettes Projekt in dem jeweiligen Zustand.
Man checkt immer nur einen Ordner aus. Also z.B: MeinProjekt\Trunk. Man hat normalerweise nie Trunk, Branches und Tags gleichzeitig auf der platte. Wäre ja auch doof, denn unter Tags 'Tagged' man normalerweise ein Release. Man hätte also jedes jemals erstellte Release der Software parallel auf der Platte. In Branch stecken entwicklungszweige, die man z.B. auch mal nicht kompilierfähig einchecken kann, ohne dass es andere Stört. Beispiel: MeinGroßesProjekt\Trunk - hier entwickeln alle an der aktuellen Version MeinGroßesProjekt\Branches\NeuesFeature - hier wird ein neues Feature entwickelt, dass erst in den Trunk kommen soll wenn es fertig ist MeinGroßesProjekt\Branches\UmbauFachklassen - hier wird etwas entwickelt, was zwangsläufig mal einen nicht kompilierfähigen stand erzeugt. Das kommt erst in den trunk wenn es fetrig ist. MeinGroßesProjekt\Tags\1.1\ - Hier ist Version 1.1 drin MeinGroßesProjekt\Tags\1.2\ - Hier Version 1.2 MeinGroßesProjekt\Tags\2.0\ - Hier Version 2... |
Re: Sinnvolle Ordnerstruktur für mehrere Projekte in Subvers
Trunk ist der Hauptzweig der Entwicklung. Normal baut man hier neue Features usw. die nicht für die Produktion geeignet sind und viele Fehler haben können.
Branches enthält parallele Entwicklungen zum Trunk oder anderen Branches. Stelle es dir als Baum vor. Parallele Entwicklung kann z.B. für Releases verwendet werden. Man zweigt vom Trunk die Entwicklung ab, weil man sagt, dass nun die komplettierten Features nun getestet und verbessert werden sollen. Nach dem Release kann mann dann dort auch noch Fehler beheben. Hat man mehrere Kunden für dasselbe Produkt mit jedoch leicht unterschiedlichen Konfigurationen, kann man so jeden Kunden mit seinem massgeschneiderten Produkt beliefern, während im Trunk neue Features entstehen. Tags enthalten Schnappschüsse vom Trunk, Branches oder Teilen davon. Sie sind im Gegensatz zu Branches fix und können/dürfen nicht verändert werden. Es sind einfach Zustandssituationen zu bestimmten Versionen. SVN vergibt zwar für jede Änderung eine eindeutige Revision, d.h. man bräuchte Tags garnicht, jedoch kann man Tags mit Namen benennen. In SVN ist es (leider) möglich, auch Tags weiter zu verändern und somit als Branch zu missbrauchen. |
Re: Sinnvolle Ordnerstruktur für mehrere Projekte in Subvers
Ein kleiner Nebenhinweis zu diesem sehr interessanten Artikel:
Es ist möglich, in SVN Pfadbasierte Berechtigungen zu setzen: ![]() Gruß alias5000 |
Re: Sinnvolle Ordnerstruktur für mehrere Projekte in Subvers
Zitat:
![]() Das kan auch svnserve, man muss es nur entsprechend einrichten. Wobei der Weg über den Apache eindeutig der flexiblere ist ;-) vgl. Crossposting in EE: ![]() |
Re: Sinnvolle Ordnerstruktur für mehrere Projekte in Subvers
Da ich alleine Programmiere ist das unerheblich mit den Zugriffsrechten. Ich habe eigentlich noch zwei Verständnisfragen.
Ich habe mir Arbeitskopien erstellt von einem Linux Server. Was passiert, wenn ich jetzt diese Arbeitskopie auf einen Windows Server mit Commit überspiele und dann wieder später auf meinen Linux Server ? Oder sollte ich da ganz die Finger von lassen ? Ich habe mir mal die Größe der Repositories angeschaut. Die ist ja um ein vielfaches kleiner als meine Arbeitskopie, wird das ganze durch die Datenbank soweit runterkomprimiert ? |
Re: Sinnvolle Ordnerstruktur für mehrere Projekte in Subvers
Du solltest sicherstellen, dass Du in deiner Arbeitskopie für jegliche Text-Files, deren Zeilenenden unter Windows und Linux verschiedenen sind (Also jeglicher Source, Textfiles, ...) das SVN-Property svn:eol-style mit dem Wert native haben. Dann gibt es da eigentlich wenig Probleme
|
Re: Sinnvolle Ordnerstruktur für mehrere Projekte in Subvers
Hallo Benny,
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:47 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz