Skip to content

Explicación breve y simple (en español) de GitHub para desarrollar y documentar un proyecto saludablemente.

Notifications You must be signed in to change notification settings

rubenrivera/GitHub-Simple

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 

Repository files navigation

GitHub Simple

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?

Se puede entender como una palabra compuesta: Git y Hub.

¿Qué es Git?

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

¿Y el Hub?

Un espacio en linea para tener un respaldo de tus proyectos.

¿Entonces...?

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.

¿Cómo hago una cuenta?

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.

Página de inicio de GitHub

¿Y ahora qué hago?

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


Repositorios

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).

Un repositorio se ve así: Repositorio de GitHub

Repasaremos la interfaz del repositorio, empezando de arriba hacia abajo. Pero primero, crearemos uno.

Crea un repositorio

En la esquina superior derecha, dale click en el ícono de +, seguido de New repository: Github new repository

Y te va a llevar a una página similar a esta: Github create repository

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 llama Pruebas y no la quieres incluir, escribres Pruebas/.

  • 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/

Encabezado

Encabezado

Contiene el propietario y el nombre del repositorio.

También hay tres botones que representan acciones:

  • Watch: Recibes notificaciones cuando hay algún cambio en el proyecto. Sirve para estar al dia.

  • Star: 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

  • Fork: 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.

Y una barra de navegación: Barra de navegación en GitHub

Vamos a explorar cada una de las pestañas, empezando por Code.

Panel de Código

Panel de código

Contiene una descripción corta del proyecto. Algunas métricas y acciones de Git. Y un listado de archivos que contiene el repositorio.

README

Es el documento que da la bienvenida a tu projecto.

README en GitHub

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).

Desarrollo guiado por README

El README es la piedra angular de un proyecto.

Mind blown

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.

Contenido de un README

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.

Ejemplos de READMEs

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.


Gestionar un repositorio

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.)

Issues

Si le damos click en la pestaña de Issues: Github issues tab

Nos aparecerá una página similar a esta: Github issues page

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í: Github open issues

Labels

Se traduce al español como etiquetas, sirve para categorizar tareas. La pantalla se ve algo así, ahí pueden agregar, editar, y eliminar etiquetas: Github Labels

Milestones

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: Github Milestones

Herramientas alternativas

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.


Documentación

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.

Wiki

Es una de las herramientas que proveé GitHub. Un lugar centralizado para documentación.

Está compuesta de páginas, como un libro.

GitHub wiki

Para más información sobre una Wiki visita la nuestra aquí: Wiki de GitHub-Simple


Fuentes documentales


Licencia de uso

Creative Commons License
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.

About

Explicación breve y simple (en español) de GitHub para desarrollar y documentar un proyecto saludablemente.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published