From Fedora Project Wiki

Java API changes checker

Contact Information

Why do you want to work with the Fedora Project?

1. I want to improve OS which I use every day. First of all, it will make my life easier.

2. I found a proposal that is very interesting to implement: Summer_coding_ideas_for_2012#Java_API.2FABI_changes_checker

3. I want to participate in development of a big real-world project. I didn't have such experience yet.

Do you have any past involvement with the Fedora project or with any another open source project as a contributor (if possible please add some references as well)?

1. No, this is my first time.

Did you participate with the past GSoC programs, if so which years, which organizations?

1. Last year I proposed an improvement to SDL([1]), but they didn't find mentor for me.

Will you continue contributing/ supporting the Fedora project after the GSoC 2012 program, if yes, which team(s)/area(s), you are interested with?

1. Of course I will continue improving project I'm done.

2. I'm interested in improving laptop support. I got a new laptop, and found that can't use some hardware under Linux.

3. I use Eclipse as my main IDE, so maybe I'll contribute to Fedora Eclipse project.

Why should we choose you over the other applicants?

1. I propose a project that I really want to implement, so I won't give up on my project after month or two.

2. I have experience in writing code in C++, Java, C#. Basically it is experience gained from courses in university. Part of my code is hosted on github: [2]

3. I can learn new things very fast, if these things are related to programming. So if it will be needed to use some library/tool unknown to me, I will be able to learn how to use it and finish project.

4. I have experience of participating in ACM ICPC and other coding competitions, so I know how to test and optimize code.

Proposal Description

Overview

Original idea: Summer_coding_ideas_for_2012#Java_API.2FABI_changes_checker

Libraries written in Java add, remove and modify their public interfaces from time to time. This is normal, but currently it is very hard to guess effect an update of library to new version will have on rest of the system. What is needed is a tool that would be able to tell us that "With update of package java-library to version 2.0, function X(b) has been removed. This function is used in package java-app"


I will create a tool that takes a set of .jar archives (and/or .class files) and tries to resolve dependencies between them like C/C++ linker do. Checking if new version of library doesn't break anything will be easy - just replace the library with new version and check dependencies again. Of course, if dependency check fails, this tool must output all information that possibly can help. And, of course, all dependency information must be generated automatically from .jars/.class files. As RPM is just a specially structured archive, it will be easy to read .jars/classes from it. Old dependency information must be kept somewhere, so error reports would contain not only message "Class/method xxx required by yyy not found", but also "Xxx was provided by zzz".

Additionally, I think another feature is useful: this tool will be able to automatically find all dependencies of a specific jar/package.

The need you believe it fulfills

Typically Java searches for a class/method at runtime when it is requested by currently executing code. If you launched a java application and it didn't report any errors at startup, you can't be sure that the application wouldn't crash because of unsatisfied dependencies later.

Proposed tool will be able to ensure that all dependencies can be resolved, without launching or even installing/unpacking java applications. It will enable easier and safer updates of java applications/libraries, and will make java package maintainers' life easier.

Any relevant experience you have

I have much experience of writing code in Java, because in my university java is used for more than half of all programming courses. Also, I am familiar with packaging system. I didn't create a new package, but at least I am able to add a patch or rebuild kernel package with my own configuration.

How do you intend to implement your proposal

I will write a set of command-line utilities that will:

1. Parse java .class files and generate lists of methods defined in classes (exports) and called by the code (imports). Parsing will be done using some third-party library, possibly it will be [[3]]. .class files will be read using standard java I/O stream classes, so loading from archive, archive-in-archive, etc. will be possible.

API changes can be viewed using diff on exports generated from multiple

2. Record exports in some database, while not removing information about older. Additional information, like .jar's name and version, or RPM package name and version (if checking RPM package) will be recorded too.

3. Try to "statically link" these libraries and report errors if occurred. If some dependency can't be satisfied, the "linker" can search the database and list library/RPM package versions that export required method or class.

These utilities can also be useful if implemented as Ant tasks.

Final deliverable of the proposal at the end of the period

Command-line Java application or/and set of Ant tasks with features described in Overview.

A rough timeline for your progress

  • May - Implement imports/exports generator utility.
  • June - Start working on "linker".
  • July - Finish linker, implement Ant tasks.
  • August - Testing/bug fixing.

I have exams in June, so most of work will be done in July.

Have you communicated with a potential mentor? If so, who?