All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.libtorrent4j.LibTorrent Maven / Gradle / Ivy

/*
 * Copyright (c) 2018-2023, Alden Torres
 *
 * Licensed under the terms of the MIT license.
 * Copy of the license at https://opensource.org/licenses/MIT
 */

package org.libtorrent4j;

import org.libtorrent4j.swig.libtorrent;
import org.libtorrent4j.swig.stats_metric;
import org.libtorrent4j.swig.stats_metric_vector;

import java.util.ArrayList;
import java.util.List;

/**
 * @author gubatron
 * @author aldenml
 */
public final class LibTorrent {

    private LibTorrent() {
    }

    /**
     * The version string as reported by libtorrent
     *
     * @return the version string
     */
    public static String version() {
        return libtorrent.version();
    }

    /**
     * The git revision of libtorrent the native library is using.
     * 

* This is not the internal revision libtorrent reports, since * that string is updated from time to time. This library can be * using an up to date revision, this string is manually * hardcoded in each version of libtorrent4j. * * @return the git revision */ public static String revision() { return "cc7459e8ed219077b1395c5ac7d808a45e7fa3f7"; } /** * Returns the version of boost used in the build. * * @return the build boost version. */ public static String boostVersion() { return libtorrent.boost_lib_version(); } /** * Returns the version of openssl used in the build. * * @return the build openssl version. */ public static String opensslVersion() { return libtorrent.openssl_version_text(); } /** * Version of libtorrent4j. It should match your maven * artifact version. * * @return libtorrent4j version. */ public static String libtorrent4jVersion() { return "2.1.0-27"; } /** * This free function returns the list of available metrics exposed by * libtorrent's statistics API. Each metric has a name and a *value index*. * The value index is the index into the array in session_stats_alert where * this metric's value can be found when the session stats is sampled (by * calling post_session_stats()). * * @return the list of all metrics */ public static List sessionStatsMetrics() { stats_metric_vector v = libtorrent.session_stats_metrics(); ArrayList l = new ArrayList<>(v.size()); for (stats_metric m : v) { l.add(new StatsMetric(m)); } return l; } /** * given a name of a metric, this function returns the counter index of it, * or -1 if it could not be found. The counter index is the index into the * values array returned by session_stats_alert. * * @param name the name of the metric * @return the index of the metric */ public static int findMetricIdx(String name) { return libtorrent.find_metric_idx_ex(name); } /** * If the native library is an ARM architecture variant, returns true * if the running platform has NEON support. * * @return true if the running platform has NEON support */ public static boolean hasArmNeonSupport() { return libtorrent.arm_neon_support(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy