Soy nuevo en GitHub y VCS en general. He estado programando en varios idiomas durante años, pero siempre he trabajado solo en proyectos personalizados (sin lanzamientos públicos). Recientemente comencé a usar un widget jQuery UI que descargué de GitHub en un proyecto en el que estoy trabajando. El repositorio ya no es mantenido por el autor original. Otra bifurcación ha incorporado algunas de las solicitudes de extracción originales. Este es el que bifurqué.
Encontré un par de errores y se me ocurrieron las soluciones. Me gustaría contribuir con estas correcciones, pero también tengo muchos otros cambios que quiero hacer, para nuestro propio uso, que romperán algunas de las características existentes. Además, me gustaría incorporar una idea de otro tenedor.
Todavía estoy aprendiendo GIT y GitHub y estoy tratando de encontrar la mejor manera de hacerlo. He leído mucho (aquí, SO, páginas de ayuda de GitHub, Pro Git) sobre diferentes conceptos / tareas: flujos de trabajo, fusión, solicitudes de extracción, selección de cerezas, rebase, ramificación. Mi materia gris está nadando y necesito comenzar a hacerlo para poder entender mejor lo que he leído.
Temas principales:
Creo que leí (en alguna parte) que solo puede tener una solicitud de extracción en una sucursal a la vez. Entonces, ¿eso significa que debería tener una rama separada para cada error y luego hacer una solicitud de extracción por separado para cada uno?
Quiero limpiar los problemas de espacios en blanco y parece recordar haber leído que es mejor hacerlo en una confirmación por separado. ¿Debo hacer esto en mi maestro o en una rama separada? No quiero hacer una solicitud de extracción para algo tan trivial , pero si hago cambios en el espacio en blanco antes de bifurcar, ¿afectará eso a la solicitud de extracción para la corrección de errores? Algunas horquillas hicieron la limpieza de espacios en blanco y efectivamente hicieron que la diferencia fuera bastante inútil.
Estaba pensando en crear problemas en mi bifurcación como una forma de documentar los errores, aunque ya tengo la solución para ellos. ¿Es eso una buena idea? ¿Cómo hago para vincular el problema, el commit y la fusión para dominar? Si hago una solicitud de extracción en sentido ascendente, ¿mi problema aparecerá también en sentido ascendente o se perderá ese enlace de documentación? No puedo abrir un problema contra el repositorio ascendente (no hay una pestaña de problema).
¿Cuál es la mejor manera de dar crédito al otro autor de la bifurcación por la idea suya que quiero usar? No puedo usar su código exactamente, especialmente porque su cambio se aplica a una versión anterior de la versión anterior y no es compatible con mis otros cambios tal como está. Pero quiero usar la idea y quiero dar crédito donde se debe. ¿Debo vincularme a su repositorio (o perfil o confirmación específica) en mi mensaje de confirmación?
¿Cuál es la etiqueta con respecto al cambio del archivo Léame y el DocBlock en la parte superior del archivo principal? ¿Está bien hacer cambios, agregar mi nombre, agregar enlaces a mi repositorio y demostración, eliminar enlaces a la demostración original (ya que mi bifurcación terminará siendo incompatible con el original)? Por supuesto, dejaré el nombre del autor original y la información de la licencia. Para el registro, está licenciado bajo la licencia MIT.
Como desarrollador en solitario que nunca ha usado VCS, estoy acostumbrado a reescribir la historia . Soy perfeccionista y me gusta que las cosas estén limpias y ordenadas. La idea de la historia grabada me está poniendo un poco nerviosa y quiero hacerlo bien la primera vez . He creado un nuevo repositorio para jugar / aprender, pero estoy ansioso por continuar arreglando el widget jQuery UI para poder continuar con mi proyecto.