Hi, Thanks for your proposal! On Wed, Feb 26, 2020 at 1:03 AM Hariom verma <hariom18599@xxxxxxxxx> wrote: > > Here is the initial version of my proposal. I would really love to > have comments on it. > Also, how should I manage the project timeline? My advice would be to look at previous proposals on the mailing list. We mostly want a project timeline that makes sense and show that you have studied on a high level the work that you will have to do. > Project title says some past GSoC and Outreachy Interns had worked on this. > I would also like to be redirected there. So I can learn from there > work as well. Thanks Abhishek for your answer about this. Yeah, please look at the work that was done, which includes what was sent to the mailing list and maybe things that weren't sent. > **Unify ref-filter formats with other --pretty formats** > > Name : Hariom Verma > Major : Computer Science and Engineering > Mobile no. : <<mob_no>> > Email : <<email>> > Time Zone : IST (UTC +05:30) > > ## About me > I am a Computer Science undergraduate at Shri G S Institute of > Technology & Science, Indore, India. I am passionate about software > freedom and open source communities. I've been writing in C, C++, > Python & Dart for almost 3 years, and contributed to some projects > which can be seen on Github. Please add a link to your GitHub page here, so that we can quickly take a look at what you contributed. > I’m contributing to Git since Oct 2019 and would love to be a member > of such a versatile community. > > ### Contact: > IRC: harry-hov (on #git-devel@freenode) > GitHub: harry-hov > Linkedin: https://www.linkedin.com/in/harry-hov/ Please move this contact information along with your name, email and time zone above. > ## Me & Git > My contributions have helped me understand the review and patch > submission process in a batter way. Also, I now feel a bit more > comfortable with Git’s codebase. > > Commit > Status > ------------------- > receive.denyCurrentBranch: respect all worktrees[1] > Status: next > > t5509: use a bare repository for test push target[2] > Status: next > > get_main_worktree(): allow it to be called in the Git directory[3] > Status: next > > git-compat-util.h: drop the `PRIuMAX` and other fallback definitions[4] > Status: Merged to master > > builtin/blame.c: constants into bit shift format[5] > Status: Merged to Master I would prefer to have the links here rather than at the end of the document. Also please add links to the commits on GitHub or GitLab. > ## Proposed Project > > ### Abstract > Git has an old problem of duplicated implementations of some logic. > For example, Git had at least 4 different implementations to format > command output for different commands. The foremost aim of this > project is to simplify codebase by getting rid of duplication of a > similar logic and, as a result, simplify adding new functionality. > The current task is to reuse ref-filter formatting logic in pretty to > minimize code duplication and to have one unified interface to extract > all needed data from the object and to print it properly. > > ### Plan > As Thomas Gummerer suggested[6] I’ll start by first looking at what > actually needed to be replaced (for example by studying the PRETTY > FORMATS section in 'man git-log', what which verbs you can use in the > ref-filter ('man git-for-each-ref') to achieve the same thing. > Then I’ll research how one format is implemented in 'pretty.c', and > see how a similar thing using the ref-filter is implemented in > 'ref-filter.c'. > e.g. the "%(objectname:short) %(contents:subject)" (this is missing > coloring, but just to get you the idea) is similar to > '--pretty=oneline'. Now one can try to find how 'oneline' is > implemented in 'pretty.c', and could translate that to use the > 'ref-filter' API. > > ### Potential Problem > The biggest challenge is to maintain backward compatibility while > using reuse ref-filter formatting logic in pretty. One can't just > delete some commands, rewrite them and change their interface. > Also, bugs could get introduced. It would be nice if you could talk about what previous people especially Olga did and what problems they faced. > ## Availability > My exams will end on 30 April. I might travel home after that. So, I > can start actively writing code for this project after 3 May. My > college resumes on 15 July. I can easily devote 45-50 hours a week > until my college reopens and 35-40 hours per week after that. I'm also > free on the weekends and I intend to complete most of the work before > my college reopens. Other than this project, I have no commitments for > this summer. I will also periodically post my status through blogs. > > ## Post GSoC > As I said, I would love to be a member of Git’s community. So, I > intend to keep contributing even after the GSoC period ends. Great! > ## Experience with Open Souce (Optional) > -> Organized many Git workshops for newcomers with HackSocIndore[7]. > HackSocIndore is a group of developers that organizes Hackathons, > Workshops & Technical Events. I’m the core team member at HackSoc. > -> Mentor, Kharagpur Winter of Code (KWoC)[8] > Kharagpur Winter of Code is a 5-week long online program for students > who are new to Open Source Development. Nice! > [8]:https://kwoc.kossiitkgp.org The above link is failing for me. Thanks, Christian.