Es complicado. Resulta difícil la primera vez que haces algo. Principalmente cuando colaboras con otros, pues cometer errores no es nada agradable. Nuestro objetivo es simplificar la forma en la que los nuevos contribuidores de open source aprenden y contribuyen por primera vez.
Leer artículos y ver tutoriales puede ayudar, pero, ¿Qué mejor que hacer las cosas en un entorno de prácticas?. Este proyecto se enfoca en ser una guía y en simplificar la forma en la que los principiantes hacen su primera contribución. Si quieres hacer tu primera contribución, sigue los pasos que se muestran a continuación.
Si no estás familiarizado con la línea de comandos, aquí hay tutoriales usando herramientas con Interfaz Gráfica (GUI).
Si no tienes git en tu equipo, puedes encontrar instrucciones para instalarlo en este enlace
Haz un fork de este repositorio haciendo click en el botón "Fork" en la parte superior derecha esta página. Esto creará una copia de este repositorio en tu cuenta.
Ahora clona este repositorio en tu equipo. Dirígete a tu cuenta de GitHub, haz click en el botón "clone or download" y luego haz click en el icono para copiar al portapapeles.
Abre tu consola o terminal y ejecuta el siguiente comando de git:
git clone "url que acabas de copiar"
Donde "url que acabas de copiar" (sin las comillas dobles) es la url a este repositorio (tu fork a este proyecto). Mira los pasos previos para obtener la url.
Por ejemplo:
git clone https://github.com/este-eres-tu/first-contributions.git
Donde este-eres-tu
es tu usuario de GitHub. Aquí estás copiando los contenidos del repositorio first-contributions en GitHub a tu equipo.
Cambia al directorio del repositorio en tu equipo (si es que no estás ahí ya).
cd first-contributions
Ahora crea una rama (branch) usando el comando git checkout
:
git checkout -b <añade tu nombre>
Por ejemplo:
git checkout -b add-alonzo-church
(El nombre de la rama no tiene por qué contener la palabra add, pero es razonable que lo tenga porque el objetivo de esta rama es añadir tu nombre a la lista.)
Abre el archivo Contributors.md
en un editor de texto y añade tu nombre. No lo añadas ni al principio ni al final del archivo, hazlo en cualquier otro sitio. Guarda el archivo.
Si vas al directorio del proyecto y ejecutas el comando git status
, verás que hay cambios.
Agrega esos cambios a la rama (branch) que creaste anteriormente usando el comando git add
:
git add Contributors.md
Ahora haz un commit sobre estos cambios ejecutando el comando git commit
:
git commit -m "Add <tu-nombre> to Contributors list"
cambiando <tu-nombre>
con tu nombre.
Haz push de tus cambios usando el comando git push
:
git push origin <añade-el-nombre-de-la-rama>
Reemplaza <añade-el-nombre-de-la-rama>
con el nombre de la rama que creaste anteriormente.
Si vas a tu repositorio en GitHub, verás un botón Compare & pull request
. Haz click sobre este botón.
Ahora envía la pull request.
Pronto estaré fusionando tus cambios (haciendo merge) con la rama master de este proyecto. Recibirás una notificación por correo electrónico cuando los cambios hayan sido fusionados.
Puedes eliminar de forma segura tu rama <añade-el-nombre-de-la-rama>
después de que la pull request haya sido fusionada. Verás este botón para eliminar la rama:
Si la Pull Request ha sido cerrada sin ser fusionada, GitHub te alertará por intentar eliminar commits no sincronizados y el botón será el siguiente:
¡Enhorabuena! ¡Has completado el flujo de trabajo fork -> clone -> edit -> PR que encontrarás habitualmente como contribuidor!
Celebra tu contribución y compártela con tus amigos y seguidores yendo a web app.
También podrías unirte a nuestro equipo de Slack en caso de que necesites ayuda o tengas alguna pregunta. Únete a nuestro Slack.
Ahora empieza a contribuir a otros proyectos. Hemos reunido una lista de proyectos con issues sencillas para que puedas empezar. Échale un ojo a la lista de proyectos en la web app.
GitHub Desktop | Visual Studio 2017 | GitKraken |
Si te gustó este proyecto, márcalo como favorito con una estrella en GitHub. Si te sientes agradecido, sigue a Roshan en Twitter y GitHub.