-
Notifications
You must be signed in to change notification settings - Fork 0
/
IntroduccionGit.Rmd
106 lines (75 loc) · 3.15 KB
/
IntroduccionGit.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
---
title: "Introducción Git"
date: '`r format(Sys.Date(), "%d de %B del %Y")`'
output:
ioslides_presentation:
css: media/presentacion.css
transition: slower
knit: (function(inputFile, encoding) {
rmarkdown::render(inputFile, encoding = encoding, output_dir = "docs", output_file = 'index.html') })
---
```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = FALSE)
```
## El código cambia y se comparte
Al escribir código existen dos problemas a resolver:
- Organizar las versiones derivadas del desarrollo
- Empatar la colaboración entre los diferentes programadores
> ¿Como compartimos código y lo mantenemos respaldado?
## Git
Git es un programa que corre en tú computadora cuyo principal objetivo es mantener el control de versiones.
Ademas permite la participación coordinada de diferentes colaboradores.
![](media/gitlogo.png){#show-logo}
## ¿Como funciona?
**Git** permite mantener un registro de cambios en los archivos, una especie fotografía del directorio.
Este directorio recibe el nombre de **repositorio**.
Cada fotografía es un **commit**, estos commit suelen incluir un mensaje con información relevante de los
cambios hechos en esta instantanea.
En conjunto estos registros contienen la **historía completa** de los cambios que se han dado en el repositorio.
## Github
Github es un servició en linea que aloja proyectos utilizando el control de versiones **Git**. Estos proyectos
pueden estar disponibles en forma **publica** o **privada**.
El servicio permite dar acceso a diferentes colaboradores manteniendo un control derivado de la autenticación con el
servicio, los permisos otorgados e incluso el esquema que se utilice.
![](media/githublogo.png){#show-logo}
## Configuración | Credenciales
Una vez instalado debemos configurar el usuario y el correo electronico que usaremos:
```{bash eva=F, echo=T}
git config --global user.name "miusuario"
git config --global user.email "[email protected]"
```
- **config** comando para configurar git
- **global** define al usuario para cualquier repositorio en nuestro equipo, sin el solo aplica para el repositorio actual.
- **user.name** y **user.email** son las credenciales que tenemos para el repositorio.
## Comandos Diarios | El mantra de git
**Git** añade pasos extras al proceso de guardar nuestros scripts. Pasos que permite **agregar** nuestros archivos a
git, crear un mensaje una especie de **registro** de cambio. Por último se **suben** los cambios al repositorio.
```{bash echo = TRUE, eval=FALSE}
git add Archivo_Modificado
git commit -m "Mensaje corto descriptivo"
git push origin master
```
## Primer paso | Agregar archivos
```{bash echo = TRUE, eval=FALSE}
### <b>
git add Archivo_Modificado
### </b>
git commit -m "Mensaje corto descriptivo"
git push origin master
```
## Segundo paso | Se agrega registro del cambio
```{bash echo = TRUE, eval=FALSE}
git add Archivo_Modificado
### <b>
git commit -m "Mensaje corto descriptivo"
### </b>
git push origin master
```
## Tercer paso | Se manda información al repositorio
```{bash echo = TRUE, eval=FALSE}
git add Archivo_Modificado
git commit -m "Mensaje corto descriptivo"
### <b>
git push origin master
### </b>
```