2013-02-16 9 views
8

Gibt es eine Entsprechung in Mercurial zu NIX Soft- oder Hardlinks zu Verzeichnissen oder Dateien.Soft Link in Mercurial

Im Grunde, dass eine Datei (oder das Verzeichnis) in eine Datei verknüpft ist „irgendwo anders“ und folgt die Fassung dieser Stelle (Im Gegensatz zu einem regulären Zweig Ich denke, wo man würde verschmelzen müssen)

Antwort

7

Mercurial Versionen weicht Links, die intern im Repository sind, sind einfach großartig. Es erkennt sie, zeichnet sie auf und erstellt sie für Sie. Gibt es einen bestimmten Anwendungsfall, nach dem Sie suchen? Einer Verbindung, die außerhalb des Repositorys ankommt, kommt eine Subrepo am nächsten, bei der es sich um einen Zeiger auf eine bestimmte Version eines anderen Repos handelt.

Symlinks arbeitet

(df)Ry4ans-MacBook-Air:~ ry4an$ hg init olav 
(df)Ry4ans-MacBook-Air:~ ry4an$ cd olav/ 
(df)Ry4ans-MacBook-Air:olav ry4an$ echo this > target 
(df)Ry4ans-MacBook-Air:olav ry4an$ ln -s target link 
(df)Ry4ans-MacBook-Air:olav ry4an$ ls -l 
total 16 
lrwxr-xr-x 1 ry4an staff  6B Feb 16 19:25 [email protected] -> target 
-rw-r--r-- 1 ry4an staff  5B Feb 16 19:25 target 
(df)Ry4ans-MacBook-Air:olav ry4an$ hg commit -A -m "link and its target" 
adding link 
adding target 
(df)Ry4ans-MacBook-Air:olav ry4an$ hg log -p 
changeset: 0:42a41a431661 
tag:   tip 
user:  Ry4an Brase <[email protected]> 
date:  Sat Feb 16 19:26:17 2013 -0500 
summary:  link and its target 

diff -r 000000000000 -r 42a41a431661 link 
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 
+++ b/link Sat Feb 16 19:26:17 2013 -0500 
@@ -0,0 +1,1 @@ 
+target 
\ No newline at end of file 
diff -r 000000000000 -r 42a41a431661 target 
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 
+++ b/target Sat Feb 16 19:26:17 2013 -0500 
@@ -0,0 +1,1 @@ 
+this 

(df)Ry4ans-MacBook-Air:olav ry4an$ hg update null 
0 files updated, 0 files merged, 2 files removed, 0 files unresolved 
(df)Ry4ans-MacBook-Air:olav ry4an$ ls -l 
(df)Ry4ans-MacBook-Air:olav ry4an$ hg update tip 
2 files updated, 0 files merged, 0 files removed, 0 files unresolved 
(df)Ry4ans-MacBook-Air:olav ry4an$ ls -l 
total 16 
lrwxr-xr-x 1 ry4an staff  6B Feb 16 19:26 [email protected] -> target 
-rw-r--r-- 1 ry4an staff  5B Feb 16 19:26 target 

Aber Hardlinks nicht

$hg commit -Am "hardlinks target" 
adding link 
adding target 
$hg log -p 
changeset: 0:ec9407634133 
tag:   tip 
user:  Chris Wesseling <[email protected]> 
date:  Wed Mar 13 23:14:44 2013 +0100 
summary:  hardlinks target 

diff -r 000000000000 -r ec9407634133 link 
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 
+++ b/link  Wed Mar 13 23:14:44 2013 +0100 
@@ -0,0 +1,1 @@ 
+foo 
diff -r 000000000000 -r ec9407634133 target 
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 
+++ b/target Wed Mar 13 23:14:44 2013 +0100 
@@ -0,0 +1,1 @@ 
+foo 

$ls -lin 
total 8 
276702 -rw-r--r-- 2 1204653 5900 4 13 mrt 23:14 link 
276702 -rw-r--r-- 2 1204653 5900 4 13 mrt 23:14 target 
$hg update null 
0 files updated, 0 files merged, 2 files removed, 0 files unresolved 
$hg update tip 
2 files updated, 0 files merged, 0 files removed, 0 files unresolved 
$ls -lin 
total 8 
276719 -rw-r--r-- 1 1204653 5900 4 13 mrt 23:15 link 
276721 -rw-r--r-- 1 1204653 5900 4 13 mrt 23:15 target 
+0

Sie meinen, es wird Handle NIX Soft-Links in den Dateien Versionierung? – Olav

+0

genau das. Siehe das obige Update. –

+0

Danke für das update @ chris-wesseling Sie haben nach soft/sym-Links gefragt, aber die Hardlink-Informationen sind auch gut. –

6

auf * nix-Systemen hg Mercurial Audits symbolische Links ("Symlinks") für bezeichneten Pfad Sicherheit. Zum Beispiel absolute und leere Pfade gelten als unsicher und werden daher nicht zum Repository hinzugefügt.

Mercurial-Entwickler haben diese Funktion nicht dokumentiert. Allerdings the source code contains a comment mit einer etwas vagen Erklärung:

class pathauditor(object): 
    '''ensure that a filesystem path contains no banned components. 
    the following properties of a path are checked: 

    - ends with a directory separator 
    - under top-level .hg 
    - starts at the root of a windows drive 
    - contains ".." 
    - traverses a symlink (e.g. a/symlink_here/b) 
    - inside a nested repository (a callback can be used to approve 
     some nested repositories, e.g., subrepositories) 
    ''' 

Unter Windows werden symbolische Links aus verschiedenen Gründen nicht unterstützt werden, finden:

+0

Symbolische Links zu absoluten Pfaden können zu einem Mercurial Repo hinzugefügt werden. Ich weiß nicht, was "leere Wege" in diesem Zusammenhang bedeutet. – Juan