|
|
|
|
Strumenti |
01-09-2009, 15:42 | #1 |
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3963
|
[Subversion]Cambio hd e ricreazione progetti
Ciao a tutti
Il disco che avevo di base si è rotto. Ho installato tutto su di un nuovo hd, installato subversion ed ora vorrei riportare i progetti dal mio pc al pc dove risiede la nuova installazione di subversion. Premetto che l'ip del pc non è cambiato ed ho assegnato alla creazione dei repository gli stessi nomi che c'erano sul vecchio. Non riesco assolutamente a capire come fare il commit o portare l'intero progetto sotto il nuovo repository. Mi dareste una mano? grazie RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek |
01-09-2009, 15:54 | #2 |
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3963
|
ok, scusate, devo prima fare il dump del repository... un pò come si fa con i db.
Ho trovato qui le info: http://www.simonecarletti.it/blog/20...ubversion-svn/ magari sono utili a qualcuno. Ciao
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek |
11-01-2010, 12:17 | #3 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Ciao,
cercavo informazioni su subversion ed ho trovato questo post. Siccome lavoro da molto ad un progetto su Eclipse, in java, ed è diventato abbastanza grande, vorrei fare in modo di utilizzare il server svn che ho appena installato sulla mia Gentoo, per tenere traccia di tutte le revisioni. Credo di avere tutti gli ingredienti, ovvero Eclipse+subeclipse plugin + subversion server, ma non so come fare per trasportare il mio progetto sul server svn. Mi sapresti aiutare? |
11-01-2010, 19:34 | #4 |
Senior Member
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 961
|
Devi usare il comando "svn import" se usi il tool da riga di comando, oppure, in Eclipse, "Team -> Condividi Progetto" sul tuo progetto. Non mi ricordo esattamente i nomi, ma dovrebbero essere più o meno quelli.
__________________
"Et Eärallo Endorenna utúlien. Sinome maruvan ar Hildinyar tenn' Ambar-metta!" -- Aragorn Elessar, Heir of Isildur Mixmar -- OpenSuSE 11.1 on AMD 64 3000+ on DFI LanParty nF4-D | GeForce 6600 GT + Thermaltake Schooner on Samsung 710N Storage -- ( 2 x Hitachi Deskstar 80 Gb + 1 x Hitachi 250 Gb ) = 1 RAID 5 + 1 Storage space LaCie Ethernet Disk Mini 250 Gb | HP - DV2150 EL MILAN CLAN |
11-01-2010, 19:43 | #5 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Ok, il problema è che quando mi chiede l'url del repository non so cosa mettere:
O meglio, quando metto https://localhost/myproject si lamenta del fatto che l'url non è specificato correttamente. Ho provato anche altre cose, come https://localhost/websvn/myproject ma niente... Non vorrei che ci sia qualche impostazione da fare sul server. |
11-01-2010, 20:47 | #6 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Finalmente!
Grazie Antonio23! Ora ha funzionato. Quindi se accedo da remoto cosa inserisco invece? Ora che ho condiviso il progetto sull'svn... come funziona per gli aggiornamenti/modifiche del progetto, ecc? |
11-01-2010, 21:05 | #7 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
In realtà il server http(s) c'è!
|
11-01-2010, 21:30 | #8 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Sì sì! Grazie, il server è già operativo e funzionante!
|
11-01-2010, 22:59 | #9 |
Senior Member
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 961
|
Se vi interessa, la stessa cosa si può fare anche con Apache e l'apposito mod. In questo caso, se si vogliono evitare le comunicazioni in chiaro e/o il phishing, si può usarlo in congiunzione con mod_ssl.
__________________
"Et Eärallo Endorenna utúlien. Sinome maruvan ar Hildinyar tenn' Ambar-metta!" -- Aragorn Elessar, Heir of Isildur Mixmar -- OpenSuSE 11.1 on AMD 64 3000+ on DFI LanParty nF4-D | GeForce 6600 GT + Thermaltake Schooner on Samsung 710N Storage -- ( 2 x Hitachi Deskstar 80 Gb + 1 x Hitachi 250 Gb ) = 1 RAID 5 + 1 Storage space LaCie Ethernet Disk Mini 250 Gb | HP - DV2150 EL MILAN CLAN |
11-01-2010, 23:03 | #10 | |
Senior Member
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 961
|
Quote:
__________________
"Et Eärallo Endorenna utúlien. Sinome maruvan ar Hildinyar tenn' Ambar-metta!" -- Aragorn Elessar, Heir of Isildur Mixmar -- OpenSuSE 11.1 on AMD 64 3000+ on DFI LanParty nF4-D | GeForce 6600 GT + Thermaltake Schooner on Samsung 710N Storage -- ( 2 x Hitachi Deskstar 80 Gb + 1 x Hitachi 250 Gb ) = 1 RAID 5 + 1 Storage space LaCie Ethernet Disk Mini 250 Gb | HP - DV2150 EL MILAN CLAN |
|
12-01-2010, 10:31 | #11 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Infatti!
Il plugin di eclipse è una figata... Lo sto usando infatti. |
17-01-2010, 17:49 | #12 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Non ho capito bene come funziona la funzione Synchronize...
Dunque, riepilogando, se io lavoro su un progetto e ho fatto delle modifiche ad una revisione: Se faccio commit, rendo persistenti le modifiche e aggiorno la revisione (ne creo una nuova) Update, mi scarica l'ultima revisione. Non capisco Synchronize. In mente ho il concetto di sincronizzazione che di solito si usa per sincronizzare un PDA con il PC quanto a appuntamenti, ecc.. ma qui, la sincronizzazione la vedo come divisa in due funzioni, appunto update e commit. Potreste farmi chiarezza? Ho cercato nella documentazione ma non trovo una spiegazione esaustiva. |
17-01-2010, 20:19 | #13 |
Senior Member
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 961
|
La funzione di "synchronize" è in realtà un' "invenzione" del plugin di Eclipse (ma penso che qualcosa di simile esista anche per altri tipi di interfacce per subversion) per visualizzare facilmente i dati. Come hai notato tu, Subversion definisce solo le funzioni di update e di commit.
L'analogia però con la sincronia del PDA non è completa: le differenze nascono considerando che Subversion è nato per la scrittura di software in modo collaborativo, quindi può capitare che le modifiche fatte da due sviluppatori diversi in modo concorrente vadano in conflitto. Invece quando si aggiorna il PDA col portatile e viceversa, normalmente l'utente è l'unico ad aver modificato i suoi dati, e quando lavora col PDA non lavora col portatile e viceversa. Se invece uno sviluppatore sviluppa il software, e agisce sullo stesso file di un'altro, facilmente si finirà per modificare le stesse parti, creando così un conflitto, che andra risolto in fase di sincronizzazione. Senza la funzione di sincronizzazione "dedicata", quello che si dovrebbe fare è verificare gli eventuali conflitti, risolverli (per questo si può usare la funzione merge), aggiornare il contenuto con update e poi "committare" i propri cambiamenti con commit. Con Eclipse, è molto più facile perchè si possono visualizzare istantaneamente gli elementi in conflitto (icona rossa), da aggiornare (icona blu) e da inviare (icona nera). Si può procedere allo stesso modo, risolvendo il conflitti e poi aggiornando e "committando". Io suggerirei di procedere in questo ordine, per evitare il rischio di sovrascrivere involontariamente modifiche altrui.
__________________
"Et Eärallo Endorenna utúlien. Sinome maruvan ar Hildinyar tenn' Ambar-metta!" -- Aragorn Elessar, Heir of Isildur Mixmar -- OpenSuSE 11.1 on AMD 64 3000+ on DFI LanParty nF4-D | GeForce 6600 GT + Thermaltake Schooner on Samsung 710N Storage -- ( 2 x Hitachi Deskstar 80 Gb + 1 x Hitachi 250 Gb ) = 1 RAID 5 + 1 Storage space LaCie Ethernet Disk Mini 250 Gb | HP - DV2150 EL MILAN CLAN |
17-01-2010, 20:30 | #14 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Grazie per la preziosa spiegazione
Ok, allora approfitto per fare un esempio, che credo (a questo punto) che sia inerente alla questione di sincronizzazione. Supponiamo che 2 sviluppatori stiano modificando (inconsapevolmente o no) lo stesso file. Stanno magari lavorando nella stessa funzione e alla riga xx, uno scrive ad esempio (per farla facile): Codice:
System.out.println("Ciao come stai?"); Codice:
System.out.println("Ciao come va?"); Si genera un "conflitto"? Lo so forse potrei fare una prova, ma ora sono da solo |
17-01-2010, 22:08 | #15 | |
Senior Member
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 961
|
Quote:
In realtà, subversion non controlla da chi è stata fatta la modifica, ma semplicemente se i cambiamente provengono da una copia del repository col numero di versione più basso di quella corrente, altrimenti si limita a creare una nuova revisione. Per esempio, nel tuo caso, se la versione di base fosse la 1, e due sviluppatori la scaricano, poi il primo la modifica e fa commit, sul repository avresti la 2: a questo punto il secondo, la cui copia è ancora ferma alla 1, prova a fare commit ma il sistema segnala un errore perchè cerca di aggiornare una revisione 2 con la sua 1. Questo implica anche che per esempio tu possa in realtà fare una prova, anche essendo da solo: semplicemente, fai il checkout del progetto in due directory diverse, e modifichi la stessa riga nello stesso file nelle due copie. A questo punto fai il commit di uno dei due: se provi a fare "synchronize" sul secondo, vedrai apparire il conflitto.
__________________
"Et Eärallo Endorenna utúlien. Sinome maruvan ar Hildinyar tenn' Ambar-metta!" -- Aragorn Elessar, Heir of Isildur Mixmar -- OpenSuSE 11.1 on AMD 64 3000+ on DFI LanParty nF4-D | GeForce 6600 GT + Thermaltake Schooner on Samsung 710N Storage -- ( 2 x Hitachi Deskstar 80 Gb + 1 x Hitachi 250 Gb ) = 1 RAID 5 + 1 Storage space LaCie Ethernet Disk Mini 250 Gb | HP - DV2150 EL MILAN CLAN |
|
17-01-2010, 22:22 | #16 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Ho capito!
Grazie! |
16-02-2010, 18:37 | #17 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Salve di nuovo.
Ho un problema con il server, o meglio quando faccio commit da Eclipse. Ho creato un nuovo repository e voglio metterci dentro un altro progetto. Al primo tentativo di condividere il progetto ricevo dei messaggi che riportano dei problemi di accesso. Ad esempio: "An internal error occurred during: "Synchronizing SVN". The resource is inaccessible: /MyProject/config.xml." La cosa strana è che quel file è leggibile da tutti, e oltretutto quando ho fatto commit, sono riuscito a scrivere quel file sul server svn. Non capisco cosa succeda. Ho anche provato a fare un refresh del progetto, ma non funziona. Inoltre, mi sapreste dire come si cancella una certa revisione di un progetto sul server svn? EDIT: Ho risolto. In pratica il riferimento a config.xml non so perché me lo impostava come "/Myproject/config.xml", e quindi con un a lettera minuscola invece che maiuscola nella dir del progetto. Non sapendo come modificare quel riferimento ho eliminato il repository e l'ho ricreato, con il nome del progetto come lo vuole lui. Ultima modifica di fbcyborg : 16-02-2010 alle 19:33. |
21-02-2010, 12:26 | #18 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Ho un problema con delle directory che rimangono fuori dal version control.
Allo stesso livello delle directory bin/ e src/ del mio progetto, ne ho altre tre, che non riesco a inserire sul server svn, con la conseguenza che quando vado a fare il checkout non me le tira giù, ovviamente. Se le seleziono e faccio Team->Commit, non me le prende. Come posso fare per inserirle sul server? EDIT: ho risolto. Il problema è che queste directory contenevano la dir .svn/ quindi il sistema le rilevava come già presenti sul server svn. Cancellandole non ci sono stati problemi a farne l'upload. Ultima modifica di fbcyborg : 21-02-2010 alle 12:57. |
24-03-2010, 21:48 | #19 | |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Salve di nuovo.
Siccome volevo lavorare al mio progetto da un altro PC, ho fatto una Update e mi sono scaricato i sorgenti aggiornati dal repository, senza alcun problema. Ora ho fatto delle modifiche, e vorrei fare un commit sul server. Il problema è che mi da il seguente errore: Quote:
Inoltre ho verificato anche i permessi della dir /var/svn/myproject, che sono 777. EDIT: per fortuna nel frattempo ho trovato la soluzione a questo URL. L'unica cosa che non mi piace è la memorizzazione in chiaro delle password nel file passwd. C'è una soluzione a questo problema? Ultima modifica di fbcyborg : 24-03-2010 alle 23:36. |
|
11-02-2011, 12:17 | #20 |
Senior Member
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
|
Sto scrivendo un documento in LaTeX e vorrei utilizzare svn per tracciare tutte le modifiche. Siccome sto usando Kile su KDE, qual'è il modo migliore per fare commit e update? Provavo da riga di comando ma non sono molto pratico.
|
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 09:38.