Package org.eclipse.jgit.lib

Examples of org.eclipse.jgit.lib.ObjectReader


  private void run(Repository db) throws Exception {
    List<Function> all = init();

    long fileCnt = 0;
    long lineCnt = 0;
    ObjectReader or = db.newObjectReader();
    try {
      final MutableObjectId id = new MutableObjectId();
      RevWalk rw = new RevWalk(or);
      TreeWalk tw = new TreeWalk(or);
      tw.reset(rw.parseTree(db.resolve(Constants.HEAD)));
      tw.setRecursive(true);

      while (tw.next()) {
        FileMode fm = tw.getFileMode(0);
        if (!FileMode.REGULAR_FILE.equals(fm)
            && !FileMode.EXECUTABLE_FILE.equals(fm))
          continue;

        byte[] raw;
        try {
          tw.getObjectId(id, 0);
          raw = or.open(id).getCachedBytes(textLimit * 1024);
        } catch (LargeObjectException tooBig) {
          continue;
        }

        if (RawText.isBinary(raw))
          continue;

        RawText txt = new RawText(raw);
        int[] lines = new int[txt.size()];
        int cnt = 0;
        HashSet<Line> u = new HashSet<Line>();
        for (int i = 0; i < txt.size(); i++) {
          if (u.add(new Line(txt, i)))
            lines[cnt++] = i;
        }

        fileCnt++;
        lineCnt += cnt;

        for (Function fun : all)
          testOne(fun, txt, lines, cnt);
      }
    } finally {
      or.release();
    }

    if (db.getDirectory() != null) {
      String name = db.getDirectory().getName();
      File parent = db.getDirectory().getParentFile();
View Full Code Here


abstract class AbstractFetchCommand extends TextBuiltin {
  @Option(name = "--verbose", aliases = { "-v" }, usage = "usage_beMoreVerbose")
  private boolean verbose;

  protected void showFetchResult(final FetchResult r) throws IOException {
    ObjectReader reader = db.newObjectReader();
    try {
      boolean shownURI = false;
      for (final TrackingRefUpdate u : r.getTrackingRefUpdates()) {
        if (!verbose && u.getResult() == RefUpdate.Result.NO_CHANGE)
          continue;

        final char type = shortTypeOf(u.getResult());
        final String longType = longTypeOf(reader, u);
        final String src = abbreviateRef(u.getRemoteName(), false);
        final String dst = abbreviateRef(u.getLocalName(), true);

        if (!shownURI) {
          outw.println(MessageFormat.format(CLIText.get().fromURI,
              r.getURI()));
          shownURI = true;
        }

        outw.format(" %c %-17s %-10s -> %s", valueOf(type), longType, //$NON-NLS-1$
            src, dst);
        outw.println();
      }
    } finally {
      reader.release();
    }
    showRemoteMessages(r.getMessages());
  }
View Full Code Here

  @Argument(index = 0)
  private ObjectId objectId;

  @Override
  protected void run() throws Exception {
    ObjectReader reader = db.newObjectReader();
    RevObject obj = new RevWalk(reader).parseAny(objectId);
    byte[] delta = getDelta(reader, obj);

    // We're crossing our fingers that this will be a delta. Double
    // check the size field in the header, it should match.
    //
    long size = reader.getObjectSize(obj, obj.getType());
    try {
      if (BinaryDelta.getResultSize(delta) != size)
        throw die("Object " + obj.name() + " is not a delta");
    } catch (ArrayIndexOutOfBoundsException bad) {
      throw die("Object " + obj.name() + " is not a delta");
View Full Code Here

    push.setRemote(remote);
    push.setThin(thin);
    push.setTimeout(timeout);
    Iterable<PushResult> results = push.call();
    for (PushResult result : results) {
      ObjectReader reader = db.newObjectReader();
      try {
        printPushResult(reader, result.getURI(), result);
      } finally {
        reader.release();
      }
    }
  }
View Full Code Here

        dircache.unlock();
    }
  }

  private void checkout() throws NoWorkTreeException, IOException {
    ObjectReader r = db.getObjectDatabase().newReader();
    try {
      for (Map.Entry<String, DirCacheEntry> entry : toBeCheckedOut
          .entrySet()) {
        File f = new File(db.getWorkTree(), entry.getKey());
        createDir(f.getParentFile());
        DirCacheCheckout.checkoutEntry(db, f, entry.getValue(), r);
        modifiedFiles.add(entry.getKey());
      }
      // Iterate in reverse so that "folder/file" is deleted before
      // "folder". Otherwise this could result in a failing path because
      // of a non-empty directory, for which delete() would fail.
      for (int i = toBeDeleted.size() - 1; i >= 0; i--) {
        String fileName = toBeDeleted.get(i);
        File f = new File(db.getWorkTree(), fileName);
        if (!f.delete())
          failingPaths.put(fileName,
              MergeFailureReason.COULD_NOT_DELETE);
        modifiedFiles.add(fileName);
      }
    } finally {
      r.release();
    }
  }
View Full Code Here

      modifiedFiles.clear();
      return;
    }

    DirCache dc = db.readDirCache();
    ObjectReader or = db.getObjectDatabase().newReader();
    Iterator<String> mpathsIt=modifiedFiles.iterator();
    while(mpathsIt.hasNext()) {
      String mpath=mpathsIt.next();
      DirCacheEntry entry = dc.getEntry(mpath);
      FileOutputStream fos = new FileOutputStream(new File(db.getWorkTree(), mpath));
      try {
        or.open(entry.getObjectId()).copyTo(fos);
      } finally {
        fos.close();
      }
      mpathsIt.remove();
    }
View Full Code Here

  private void checkoutPathsFromIndex(TreeWalk treeWalk, DirCache dc)
      throws IOException {
    DirCacheIterator dci = new DirCacheIterator(dc);
    treeWalk.addTree(dci);

    final ObjectReader r = treeWalk.getObjectReader();
    DirCacheEditor editor = dc.editor();
    while (treeWalk.next()) {
      DirCacheEntry entry = dci.getDirCacheEntry();
      // Only add one edit per path
      if (entry != null && entry.getStage() > DirCacheEntry.STAGE_1)
View Full Code Here

  }

  private void checkoutPathsFromCommit(TreeWalk treeWalk, DirCache dc,
      RevCommit commit) throws IOException {
    treeWalk.addTree(commit.getTree());
    final ObjectReader r = treeWalk.getObjectReader();
    DirCacheEditor editor = dc.editor();
    while (treeWalk.next()) {
      final ObjectId blobId = treeWalk.getObjectId(0);
      final FileMode mode = treeWalk.getFileMode(0);
      editor.add(new PathEdit(treeWalk.getPathString()) {
View Full Code Here

    int commits = 0;
    int minN = Integer.MAX_VALUE;
    int maxN = 0;

    AbbreviatedObjectId startId;
    ObjectReader or = db.newObjectReader();
    try {
      final MutableObjectId id = new MutableObjectId();
      RevWalk rw = new RevWalk(or);
      TreeWalk tw = new TreeWalk(or);
      tw.setFilter(TreeFilter.ANY_DIFF);
      tw.setRecursive(true);

      ObjectId start = db.resolve(Constants.HEAD);
      startId = or.abbreviate(start);
      rw.markStart(rw.parseCommit(start));
      for (;;) {
        final RevCommit c = rw.next();
        if (c == null)
          break;
        commits++;
        if (c.getParentCount() != 1)
          continue;

        RevCommit p = c.getParent(0);
        rw.parseHeaders(p);
        tw.reset(p.getTree(), c.getTree());
        while (tw.next()) {
          if (!isFile(tw, 0) || !isFile(tw, 1))
            continue;

          byte[] raw0;
          try {
            tw.getObjectId(id, 0);
            raw0 = or.open(id).getCachedBytes(textLimit * 1024);
          } catch (LargeObjectException tooBig) {
            continue;
          }
          if (RawText.isBinary(raw0))
            continue;

          byte[] raw1;
          try {
            tw.getObjectId(id, 1);
            raw1 = or.open(id).getCachedBytes(textLimit * 1024);
          } catch (LargeObjectException tooBig) {
            continue;
          }
          if (RawText.isBinary(raw1))
            continue;

          RawText txt0 = new RawText(raw0);
          RawText txt1 = new RawText(raw1);

          minN = Math.min(minN, txt0.size() + txt1.size());
          maxN = Math.max(maxN, txt0.size() + txt1.size());

          for (Test test : all)
            testOne(test, txt0, txt1);
          files++;
        }
        if (count > 0 && files > count)
          break;
      }
    } finally {
      or.release();
    }

    Collections.sort(all, new Comparator<Test>() {
      public int compare(Test a, Test b) {
        int cmp = Long.signum(a.runningTimeNanos - b.runningTimeNanos);
View Full Code Here

      if (current.equals(Constants.HEAD))
        addRef("(no branch)", head); //$NON-NLS-1$
      addRefs(refs, Constants.R_HEADS, !remote);
      addRefs(refs, Constants.R_REMOTES, remote);

      ObjectReader reader = db.newObjectReader();
      try {
        for (final Entry<String, Ref> e : printRefs.entrySet()) {
          final Ref ref = e.getValue();
          printHead(reader, e.getKey(),
              current.equals(ref.getName()), ref);
        }
      } finally {
        reader.release();
      }
    }
  }
View Full Code Here

TOP

Related Classes of org.eclipse.jgit.lib.ObjectReader

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.