I have this java code and caught a nullPointerException when I run it.
Through debugging using eclipse, I found out that msiLine parameter is null but I can't find out why.
                String msiAbsolutePath = msiFiles.getAbsolutePath();
                String filePath = msiAbsolutePath.substring(0,msiAbsolutePath.lastIndexOf(File.separator));
                new File(filePath+"/Emboss").mkdir();
                new File(filePath+"/Report").mkdir();
                File files = sort(msiFiles,filePath);
                BufferedReader msiReader = new BufferedReader(new FileReader(files));
                BufferedReader embReader = new BufferedReader(new FileReader(embFiles));
                String[] msiTokens = msiFiles.getName().split("\\.(?=[^\\.]+$)");
                String[] embTokens = embFiles.getName().split("\\.(?=[^\\.]+$)");
                final String msiFileName = msiTokens[0];
                final String embFileName = embTokens[0];
                Date date = new Date();
                DateFormat dateFormatName = new SimpleDateFormat("MMdd");
                PrintWriter msiWrite = new PrintWriter(new BufferedWriter(new FileWriter(filePath+"/Emboss/"+msiFileName+".PRN")));
                PrintWriter embWrite = new PrintWriter(new BufferedWriter(new FileWriter(filePath+"/Emboss/"+embFileName+".PRN")));
                PrintWriter reportWrite = new PrintWriter(new BufferedWriter(new FileWriter(filePath+"/Report/CS"+dateFormatName.format(date)+".RPT")));
                cnt=totalLines=0;
                //String msiLine = msiReader.readLine();
                String msiLine="";
                String embLine = embReader.readLine();
        here>>> for(msiLine = msiReader.readLine(); msiLine.length() >= 60; msiLine = msiReader.readLine())
                {
                    embLine = embReader.readLine();
                    msiWrite.print();
                    :
                    :
                    }
                    statMessage = "Completed " + current + " out of " + lengthOfTask + ".";
                }
                :
                :
            }catch(IllegalStateException | IOException | NullPointerException d){
                d.printStackTrace();
            }
        }
    }
    File sort(File file, String filepath){
        File files = new File(filepath + "\\tempMSIfile.msi");
        try{
            BufferedReader reader = new BufferedReader(new FileReader(file));
            Map<String, String> map=new TreeMap<String, String>();
            String line=reader.readLine();
            for(line = reader.readLine(); line.length() >= 60; line = reader.readLine()){
                map.put(getField(line),line);
            }
            reader.close();
            PrintWriter writer = new PrintWriter(new BufferedWriter(new FileWriter(files)));
            for(String val : map.values()){
                writer.print("" +val);  
                writer.print(NEWLINE);
            }
            writer.close();
        }catch(IllegalStateException | IOException | NullPointerException d){
            LOG.fine("Error, " + d.getMessage());
        }
        return files;
    }
    String getField(String line) {
        return line.substring(10, 26);//extract value you want to sort on
    }
Can somebody explain to me why is the msiLine is null?
I think it involves the File files = sort(msiFiles,filePath); but the eclipse report that files parameter does have the correct file/thing(?) assigned to it.
In case anyone wondering, tempMSIfile.msi is not empty.
 
     
     
    