Hago mucho desarrollo en mi propio tiempo. Estos proyectos en los que trabajo son solo para divertirse y aprender (hasta ahora). Comúnmente desarrollo Java con Maven, pero también se me conoce por incursionar en .NET y Python. Todos los proyectos en los que trabajo utilizan licencias de código abierto, aunque la mayoría de ellos no se encuentran en ningún repositorio de código público.
El desarrollo de Java / Maven requiere que use una estructura única groupId
(por ejemplo, "com.mydomain") y una package
estructura única (directorio), que generalmente contiene el groupId
desarrollo .NET mientras que fomenta un namespaces
uso único en convenciones similares al package
concepto de Java . Para garantizar la unicidad, usualmente solo uso uno de mis nombres de dominio con las partes invertidas (por ejemplo, "ca.jessewebb"); Creo que esta es una práctica muy común.
Estoy en las etapas iniciales de crear un nuevo proyecto Java / Maven de código abierto (llamémoslo "newproj") y me gustaría ponerlo en GitHub. Mi nombre de usuario en GitHub es "jessewebb" por lo que esto le dará una URL como: https://github.com/jessewebb/newproj
. No quiero molestarme en registrar el nombre de dominio "newproj.com", así que decidí usar "ca.jessewebb" y "ca.jessewebb.newproj" como groupId
y package
, respectivamente.
Se me ocurrió que la presencia de mi identidad personal en el código y como parte de la casa del proyecto (en la URL de GitHub) probablemente hará que un contribuyente potencial piense dos veces antes de involucrarse en mi proyecto. Esto es un problema, no quiero que sea mi proyecto. Preferiría si pudiera, en cambio, transmitir el mensaje de que no soy dueño del proyecto. Ahora, con toda honestidad, realmente no es un gran problema porque dudo que mis proyectos obtengan mucha participación de la comunidad, pero también veo esto como una razón aún más para evitar cualquier posibilidad de disuadir a los posibles contribuyentes.
Para otro ejemplo, creé un proyecto de Google Code hace unos años (llamémoslo "oldproj"). Cuando creé el proyecto, sabía que iba a alojarlo en Google Code, así que utilicé el groupId
nombre del paquete "com.googlecode.oldproj", que es el reverso del nombre de dominio predeterminado que Google Code proporciona en cada nuevo proyecto. Esto resultó ser una idea no tan genial; Un año más tarde, moví el código a un repositorio diferente y tuve que cambiar el nombre de estos identificadores (bueno, no teníaa pero ...). En ese momento, no poseía ningún nombre de dominio y terminé comprando el nombre de dominio "oldproj.com" y lo usé. Me gustó esto porque le dio al proyecto su propia identidad y no estaba estampando mi nombre en el código en todas partes. Podría haber registrado con la misma facilidad el nombre de dominio "jessewebb.ca" y haber usado "ca.jessewebb.oldproj" como el nombre del paquete, pero no lo hice porque tenía las mismas preocupaciones en ese entonces también.
Entonces mi pregunta es ...
¿Cómo puedo evitar usar mis propios nombres (de dominio) al crear proyectos de código abierto y al mismo tiempo mantener la unicidad de los paquetes / espacios de nombres?
A medida que los proyectos ganan más impulso, tiene sentido registrar los nombres de dominio, pero parece una tontería y una pérdida de dinero hacer esto antes. Me doy cuenta de que en realidad no tengo que tener el nombre de dominio para usarlo en el código, pero eso se siente mal y puede hacer que un okupa te lo arrebata mientras tanto. ¿Qué hacen otras personas sobre este dilema? ¿Hay ejemplos de proyectos de código abierto populares (ampliamente utilizados, de gran comunidad, etc.) que contengan la identidad del desarrollador original como parte de sus propios identificadores?