Supongo que trabajas con un equipo de programadores, y por alguna razón te preguntaron por tu cuenta de GitHub. Si no tienes idea de por dónde empezar, esta guía es una buena introducción.
El siguiente texto está dirigido a investigadores, diseñadores, supervisores de proyectos, y demás roles que no tienen que ver directamente con programación.
Indice:
- ¿Qué es GitHub?
- Repositorios
- Gestionar un repositorio
- Documentación
- Fuentes documentales
- Licencia de uso
Se puede entender como una palabra compuesta: Git y Hub.
Una herramienta que facilita la colaboración:
Imagínate que tú y Beto deciden dibujar juntos en la escuela, pero quieren terminar el dibujo cada quien en su casa. La maestra saca 2 fotocopias de lo que hicieron en clase y se la llevan a casa (clone | pull).
Tanto como tú y Beto le añaden cosas al dibujo (add), y a cada cosa que añaden le ponen una nota explicando lo que agregaron (commit).
Cuando regresan a la escuela, la maestra corta y pega los dibujos en uno solo (merge), si ambos colorearon la misma área (merge conflict) alguien decide qué versión se usa, si la de Beto o la tuya.
Y como son fotocopias, pueden hacer los cambios que quieran sin dañar el original.
Si deciden ver quién hizo qué cambio y por qué, sólo basta con ver las notas que anexaron tú y Beto (log). Y hasta pueden comparar las 2 versiones (diff).
Si alguien más quiere dibujar con ustedes, sólo necesita una copia del original (clone).
Ese sería un flujo de trabajo con Git. Las palabras que están en negritas es el nombre en inglés que se le da a esa acción.
Si son de los que olvidan los comandos de Git, aquí los pueden checar: Hoja de comandos de Git en español
Y si quieres meterle esteroides a tu Git, checa este enlace: Git Extras
Por favor, traten de usar la guía de estilo: Guía de estilo de Git
Un espacio en linea para tener un respaldo de tus proyectos.
GitHub es un espacio en linea para tener un respaldo de tus proyectos que usen Git, enfocado a proyectos de programación con código abierto.
Cuando digo código abierto me refiero a que la gente pueda ver cómo está construido el proyecto (ver el código fuente).
Los proyectos están organizados en repositorios. Es un lugar donde se almacenan los archivos que conforman el proyecto.
Crear una cuenta en GitHub es gratuito, siempre y cuando tus proyectos sean abiertos al público. Si quieres restringir el acceso a tus proyectos puedes pagar por ello una subscripción mensual.
Ingresa a la página principal de Github y en los campos
de texto llena tu nombre de usuario
, correo electrónico
, y contraseña
.
Si ya tienes un proyecto en el que estés trabajando, ve al repositorio.
El enlace se debe de ver algo así:
http://github.com/usuario/nombre-del-repositorio
O puedes crear un repositorio
Es el lugar donde están todos los archivos del proyecto, incluyendo la documentación. Los repositorios pueden tener multiples colaboradores y pueden ser publicos (que el acceso esté abierto a cualquiera) o privados (restringe el acceso a las personas que autorices).
Repasaremos la interfaz del repositorio, empezando de arriba hacia abajo. Pero primero, crearemos uno.
En la esquina superior derecha, dale click en el ícono de +
, seguido
de New repository
:
Y te va a llevar a una página similar a esta:
Vienen varios campos que tienes que llenar:
-
Owner: El dueño del repositorio (puedes ser tú o alguna organización a la que pertenezcas).
-
Repository name: Un nombre corto y memorable para identificarlo.
-
Description: Descripción breve del contenido.
-
Public / Private: Si el acceso eso abierto o restringido.
-
Initialize with README: Añade un README al repositorio.
-
Add .gitignore: Es un archivo de texto que le dice a Git qué archivos ignorar. Por ejemplo, si no quieres tener archivos PDF, en el
.gitignore
escribes*.pdf
, o si tienes una carpeta que se llamaPruebas
y no la quieres incluir, escribresPruebas/
. -
Add a license: Sólo por que tus archivos estén en internet, no significa que sean libres de usar o de dominio público. Esta opción genera un archivo que se llama LICENSE, y deja en claro qué se puede hacer con los archivos y qué no.
Si tienes duda respecto a las licencias de uso, visita: http://choosealicense.com/
Contiene el propietario y el nombre del repositorio.
También hay tres botones que representan acciones:
-
: Recibes notificaciones cuando hay algún cambio en el proyecto. Sirve para estar al dia.
-
: Se utilizan para tener fácil acceso a un proyecto, y para mostrarle tu amor al repositorio, similar a los likes en Facebook 👍. Si quieres ordenar tus Stars puedes utilizar AstralApp
-
: Haces una copia del repositorio en tu cuenta de GitHub (recuerda las fotocopias que se llevaron Beto y tú), así puedes hacer cambios sin afectar el original. También te permite sugerir cambios y traer actualizaciones del original a tu fork. Se utilizan para iterar sobre ideas e implementaciones manteniendo el original intacto.
Vamos a explorar cada una de las pestañas, empezando por Code.
Contiene una descripción corta del proyecto. Algunas métricas y acciones de Git. Y un listado de archivos que contiene el repositorio.
Es el documento que da la bienvenida a tu projecto.
Se traduce del inglés como LEEME.
Sirve como introducción, y es un buen lugar para explicar o vender tu idea. Si quieres que la gente utilice y/o contribuya a tu proyecto, aquí debes de convencerlos.
Normalmente las personas ven el README en un navegador, y para que no se vea
como un simple texto, se le agrega formato utilizando
Markdown (de ahí viene la extención de archivo .md
).
El README es la piedra angular de un proyecto.
Si empiezas por escribir un documento sencillo que sirva como introducción, quien colabore podrá tener siempre presente el ¿Por qué? y ¿Para qué? del proyecto, mejorando la comunicación y respaldando que todos estén apuntando a la misma dirección.
Te ayudará a conocer qué implementar para cumplir los ideales del proyecto.
Además, es un esquema bastante sencillo para aterrizar las ideas. Facilita que se pueda discutir e iterar sin perder el rumbo.
Un buen README debe tener al menos estos elementos:
-
Descripción: ¿De qué trata el repositorio? ¿Por qué me debería importar?
-
Sociales: (Opcional) Si tu proyecto tiene algún Blog, Twitter, etc. inclúyelos
-
Instrucciones de uso: Proceso de instalación, comandos, interfaz gráfica, etc.
-
Dónde obtener ayuda: Enlaces a documentación, Wiki, Foros, etc.
-
Guía de contribución: Especifica formato del código, convenciones, cómo abrir un ticket para seguimiento de problemas, cómo presentar los cambios, etc. Normalmente se encuentra en un archivo aparte, nombrado CONTRIBUTING. La función de esta sección es crear orden y facilitarle el trabajo a quien mantiene el repositorio.
-
Lista de contribuidores: Las personas que están atrás del proyecto. Si son demasiadas, inclúyelas en un archivo aparte CONTRIBUIDORES. Puedes utilizar esta herramienta para darles un buen formato: Generador de tabla de contribuidores
-
Fuentes, inspiración: Da reconocimiento si utilizaste ideas o material de otros proyectos. También les ayuda a los contribuyentes a tener una perspectiva más amplia.
-
Licencia de uso: En la creación de un repositorio hablamos al respecto. Esta licencia puede ir en un archivo llamado LICENSE o incluido en el README. Si está en LICENSE no olvides mencionarlo en el README.
Una lista de READMEs para ejemplificar casos de buenas prácticas.
-
Deep Belief SDK: Descripción, tabla de contenido, instrucciones de uso muy claras, instalación, ejemplos de uso, preguntas frecuentes, licencia, créditos.
-
twtxt: Descripción, demostración en video, tabla de contenido, instrucciones de uso muy claras, contribuciones, licencia.
-
GrapeJS: Descripción, características con imágenes, instrucciones de uso muy claras, instalación, contribución, licencia.
-
PHP brew: Descrpición, traducciones (chino), instalación, instrucciones de uso muy claras, guía de contribución, documentación, licencia.
-
spf13-Vim: Descripción, instalación, imágenes, instrucciones de uso muy claras, licencia.
-
Underscore CLI: Descripción, instalación, ejemplos con imágenes, instrucciones de uso muy claras, cómo reportar erroes, inspiración, licencia.
La mayoría de los problemas de nuestro trabajo no son tanto técnicos como sociológicos en su naturaleza.
Uno de los retos más grandes de un proyecto open source, es lidiar con las personas. Cuando facilitas la comunicación, haciendo explícitas las tareas y metas que se quieren cumplir, no suele ser tan complicado.
Para ésto, hay metodologías que se pueden seguir, la más utilizada en el desarrollo de software es la ágil. Te recomiendo leer más sobre desarrollo ágil, ya que te ayudará a organizarte mejor con tu equipo
Una vez que escribes una definición del proyecto (README), puedes empezar a definir tareas y metas explícitas.
Algunas herramientas de GitHub te permiten tener todo centralizado:
-
Issues: Tareas que se necesiten cumplir, ya sea arreglar un problema o agregar una mejora al proyecto.
-
Labels: Etiquetas para categorizar las tareas
-
Milestones: Metas u objetivos, están compuestos de muchas tareas.
-
Pull requests: Petición de algún cambio, ya sea agregar o quitar información del repositorio (archivos, lineas de código, arreglar errores, implementar mejoras, etc.)
Si le damos click en la pestaña de Issues:
Nos aparecerá una página similar a esta:
Ahí pueden empezar a crear tareas. La interfaz es muy simple, sólo recuerden ser explícitos a la hora de nombrar y describir las tareas. Estas pueden ser historias de usuario, necesidades del proyecto, etc. Para seguir un estandar, se utiliza la Guía de contribución. Tengan en cuenta a quién va dirigida la tarea, incluye referencias explicando qué quieres y cómo lo quieres.
Después de que hayan escrito algunas, se verán algo así:
Se traduce al español como etiquetas, sirve para categorizar tareas. La pantalla se ve algo así, ahí pueden agregar, editar, y eliminar etiquetas:
En sí, es un conjunto de tareas. Puede ser un lanzamiento, una módulo del proyecto, una revisión, etc. Incluyen una descripción, fecha, y las tareas que se necesitan cumplir para lograr ese objetivo.
Se puede decir que los issues son metas a corto plazo y los milestones son a largo plazo.
La pantalla de los milestones se ve algo similar:
Existen herramientas que te pueden ayudar a administrar mejor tu repositorio. Si estás acostumbrado a utilizar un Kanban para tus tareas, puedes utilizar Waffle.io.
Puedes encontrar más integraciones de GitHub en: https://github.com/integrations
El consumo excesivo de integraciones puede ser dañino para la salud de un proyecto. Integra con medida.
Estarás usando tu código dentro de 6 meses.
La mejor razón para escribir documentación, es por que tenemos mala memoría. Cuando querramos retomar el proyecto, se nos habrá olvidado la mayoría de las cosas. Sí tan solo hubiera escrito el por qué de esto, la vida sería más simple.
La documentacíon expesa lo que hay detrás del código. Se enfoca en el por qué en lugar del cómo. Sí las personas no saben el propósito de tu proyecto, no lo usarán ni serán contribuyentes.
La primera documentación que se debe escribir es el README.
Una vez que esté más estructurado el proyecto, puedes expandir la documentación a una Wiki.
Es una de las herramientas que proveé GitHub. Un lugar centralizado para documentación.
Está compuesta de páginas, como un libro.
Para más información sobre una Wiki visita la nuestra aquí: Wiki de GitHub-Simple
- Explicación sencilla de Git
- Awesome GitHub
- Awesome README
- Guías de GitHub
- Guía corta para escribir guías
- Write the docs
Github-Simple by MrOutis is licensed under a Creative Commons Attribution 4.0 International License.
Based on a work at https://github.com/MrOutis/GitHub-Simple.