abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 13:22 | Komunita

    Vývoj linuxové distribuce Clear Linux (Wikipedie) vyvíjené společností Intel a optimalizováné pro jejich procesory byl oficiálně ukončen.

    Ladislav Hagara | Komentářů: 1
    včera 14:00 | Zajímavý článek

    Byl publikován aktuální přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    včera 12:00 | Nová verze

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 12.0 (Mastodon). Forgejo je fork Gitei.

    Ladislav Hagara | Komentářů: 0
    17.7. 18:44 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 155 (pdf) a Hello World 27 (pdf).

    Ladislav Hagara | Komentářů: 1
    17.7. 16:11 | Nová verze

    Hyprland, tj. kompozitor pro Wayland zaměřený na dláždění okny a zároveň grafické efekty, byl vydán ve verzi 0.50.0. Podrobný přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 2
    17.7. 15:55 | Komunita

    Patrick Volkerding oznámil před dvaatřiceti lety vydání Slackware Linuxu 1.00. Slackware Linux byl tenkrát k dispozici na 3,5 palcových disketách. Základní systém byl na 13 disketách. Kdo chtěl grafiku, potřeboval dalších 11 disket. Slackware Linux 1.00 byl postaven na Linuxu .99pl11 Alpha, libc 4.4.1, g++ 2.4.5 a XFree86 1.3.

    Ladislav Hagara | Komentářů: 5
    16.7. 21:22 | IT novinky

    Ministerstvo pro místní rozvoj (MMR) jako první orgán státní správy v Česku spustilo takzvaný „bug bounty“ program pro odhalování bezpečnostních rizik a zranitelných míst ve svých informačních systémech. Za nalezení kritické zranitelnosti nabízí veřejnosti odměnu 1000 eur, v případě vysoké závažnosti je to 500 eur. Program se inspiruje přístupy běžnými v komerčním sektoru nebo ve veřejné sféře v zahraničí.

    Ladislav Hagara | Komentářů: 19
    16.7. 16:22 | IT novinky

    Vláda dne 16. července 2025 schválila návrh nového jednotného vizuálního stylu státní správy. Vytvořilo jej na základě veřejné soutěže studio Najbrt. Náklady na přípravu návrhu a metodiky činily tři miliony korun. Modernizovaný dvouocasý lev vychází z malého státního znaku. Vizuální styl doprovází originální písmo Czechia Sans.

    Ladislav Hagara | Komentářů: 26
    16.7. 15:33 | Upozornění

    Vyhledávač DuckDuckGo je podle webu DownDetector od 2:15 SELČ nedostupný. Opět fungovat začal na několik minut zhruba v 15:15. Další služby nesouvisející přímo s vyhledáváním, jako mapyAI asistent jsou dostupné. Pro některé dotazy během výpadku stále funguje zobrazování například textu z Wikipedie.

    bindiff | Komentářů: 8
    16.7. 13:33 | Bezpečnostní upozornění

    Více než 600 aplikací postavených na PHP frameworku Laravel je zranitelných vůči vzdálenému spuštění libovolného kódu. Útočníci mohou zneužít veřejně uniklé konfigurační klíče APP_KEY (např. z GitHubu). Z více než 260 000 APP_KEY získaných z GitHubu bylo ověřeno, že přes 600 aplikací je zranitelných. Zhruba 63 % úniků pochází z .env souborů, které často obsahují i další citlivé údaje (např. přístupové údaje k databázím nebo cloudovým službám).

    Ladislav Hagara | Komentářů: 6
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (17%)
     (33%)
     (17%)
     (0%)
     (0%)
     (0%)
     (0%)
     (33%)
    Celkem 6 hlasů
     Komentářů: 1, poslední dnes 13:41
    Rozcestník
    Štítky: není přiřazen žádný štítek


    Vložit další komentář
    4.3.2010 09:39 Foo Bar | skóre: 14
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    Chtěl jsem napsat cosi jako oh the horrors, oh the horrors, ale pak jsem si všiml kategorie Humor :)
    alblaho avatar 4.3.2010 09:49 alblaho | skóre: 17 | blog: alblog
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    Bohužel mi to nefunguje. Každá aktualizace progresu se vypíše na nový řádek.
    4.3.2010 12:36 pc2005 | skóre: 38 | blog: GardenOfEdenConfiguration | liberec
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    Mě to funguje (pouštěl jsem to jako bash skript s parametrama). Akorát při velkých souborech (10MB) se ten progress bar nezastaví.
    Limoto avatar 4.3.2010 10:27 Limoto | skóre: 32 | blog: Limotův blog
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    4.3.2010 10:32 xm | skóre: 36 | blog: Osvobozený blog | Praha
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    Use rsync, Luke! ;-) Ale jako hack je to opravdu luxusní (jen kdyby strace nebylo tak zatraceně pomalé :-)).
    Svoboda je tím nejdůležitějším, co máme. Nenechte se o ní připravit, podporujte Pirátskou stranu!
    4.3.2010 10:38 David Watzke
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    Hehe, já občas použiju tar|pv, ale v KDE lze taky použít grafický kde-cp, a tak...
    4.3.2010 12:48 jas | skóre: 13 | blog: blag
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    Osobne som skor cakal, ze si pustia read only ftp server na / a pouziju wget, ale aj toto je riesenie. :)
    4.3.2010 13:49 ruza
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    par let zpatky fungoval nedokumentovany prepinac "cp -g". nebyl v man ani napovede pres -h ale delal co bylo treba
    4.3.2010 14:33 xm | skóre: 36 | blog: Osvobozený blog | Praha
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    Nebyl to náhodou nějaký distribuční patch na coreutils? IMHO v oficiálních coreutils to není a nikdy nebylo.
    Svoboda je tím nejdůležitějším, co máme. Nenechte se o ní připravit, podporujte Pirátskou stranu!
    4.3.2010 15:39 Jiří J. | skóre: 34 | blog: Poutník | Brno
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    To já znám zas cwp.c :-)
    /*
     * cwp.c: catenate with progress
     *
     * Copyright (c) 2001 Chris Lightfoot. All rights reserved.
     *
     */
    
    static char rcsid[] = "$Id: cwp.c,v 1.2 2001/01/19 00:26:17 chris Exp $";
    
    #include <errno.h>
    #include <fcntl.h>
    #include <signal.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <time.h>
    #include <unistd.h>
    
    #include <sys/stat.h>
    #include <sys/time.h>
    
    #define BLOCKSIZE       65536
    #define TIMESTEP        10.     /* number of seconds over which rate will be calculated */
    
    int columns = 80; /* width of screen */
    
    /* timeoffset:
     * Returns the number of seconds since some time.
     */
    float timeoffset(const time_t t0) {
        struct timeval tv;
        gettimeofday(&tv, NULL);
        tv.tv_sec -= t0;
        return (float)tv.tv_sec + 1e-6 * (float)tv.tv_usec;
    }
    
    /* size:
     * Return a string describing the size of something.
     */
    char *strsize(const int width, const int len) {
        static char str[64];
        if (len > 10000000)
            sprintf(str, "% *.1f Mb", width - 3, (float)len / 1048576.);
        else if (len > 10000)
            sprintf(str, "% *.1f Kb", width - 3, (float)len / 1024.);
        else
            sprintf(str, "% *d b", width - 2, len);
        return str;
    }
    
    /* file_copy_progress:
     * Copy data from a file to some file descriptor, with a progress indicator
     * which indicates what fraction of the file has been copied.
     */
    void file_copy_progress(char *f, int o, size_t size) {
        int i;
        ssize_t j, total = 0;
        char *buf;
        time_t tst;
        float t0 = 0., t1, t2;
        ssize_t n0, n1, n2;
    
        i = open(f, O_RDONLY);
        if (i == -1) {
            perror(f);
            return;
        }
    
        buf = (char*)malloc(BLOCKSIZE);
    
        tst = time(NULL);
        t0 = timeoffset(tst);
        n0 = 0;
    
        while ((j = read(i, buf, BLOCKSIZE))) {
            ssize_t k;
            float rate;
    
            if (j == -1 && errno != EINTR) {
                fprintf(stderr, "\n");
                perror(f);
                close(i);
                free(buf);
                return;
            }
    
            for (k = 0; k < j; ) {
                ssize_t l;
                l = write(o, buf + k, j - k);
                if (l == -1 && errno != EINTR) {
                    fprintf(stderr, "\n");
                    perror(f);
                    close(i);
                    free(buf);
                    return;
                }
                k += l;
                total += l;
            }
    
            t1 = timeoffset(tst);
            if ((t1 - t0) > TIMESTEP / 2.) {
                t2 = timeoffset(tst);
                n2 = total;
            }
            if ((t1 - t0) > TIMESTEP) {
                t0 = t2;
                n0 = n2;
            }
    
            /* Print a progress indicator. */
            fprintf(stderr, "%.*s: written %s/",
                    columns - 55,
                    f, strsize(9, total));
            fprintf(stderr, "%s % 5.1f%% ",
                    strsize(9, size),
                    100. * ((float)total/(float)size));
    
            rate = ((float)(total - n0) / (t1 - t0));
            if (rate < 0.) rate = 0.;
            if (rate > 1e7)
                fprintf(stderr, "% 5.1f Mb/s", rate / 1048576.0);
            else if (rate > 1e4)
                fprintf(stderr, "% 5.1f Kb/s", rate / 1024.0);
            else
                fprintf(stderr, "% 5.1f b/s", rate);
    
            fprintf(stderr, "  \r");
        }
    
        free(buf);
    }
    
    /* pipe_copy_progress:
     * Copy data from a nonseekable thing to a file descriptor, with a progress
     * indicator which indicates how many bytes have been copied.
     */
    void pipe_copy_progress(char *f, int i, int o) {
        ssize_t j, total = 0;
        char *buf;
        time_t tst;
        float t0 = 0., t1, t2;
        ssize_t n0, n1, n2;
    
        buf = (char*)malloc(BLOCKSIZE);
    
        tst = time(NULL);
        t0 = timeoffset(tst);
        n0 = 0;
    
        while ((j = read(i, buf, BLOCKSIZE))) {
            ssize_t k;
            float rate;
    
            if (j == -1 && errno != EINTR) {
                fprintf(stderr, "\n");
                perror(f);
                close(i);
                free(buf);
                return;
            }
    
            for (k = 0; k < j; ) {
                ssize_t l;
                l = write(o, buf + k, j - k);
                if (l == -1 && errno != EINTR) {
                    fprintf(stderr, "\n");
                    perror(f);
                    close(i);
                    free(buf);
                    return;
                }
                k += l;
                total += l;
            }
    
            t1 = timeoffset(tst);
            if ((t1 - t0) > TIMESTEP / 2.) {
                t2 = timeoffset(tst);
                n2 = total;
            }
            if ((t1 - t0) > TIMESTEP) {
                t0 = t2;
                n0 = n2;
            }
    
            /* Print a progress indicator. */
            fprintf(stderr, "%.*s: written %s ",
                    columns - 20,
                    f, strsize(9, total));
    
            rate = ((float)(total - n0) / (t1 - t0));
            if (rate < 0.) rate = 0.;
            if (rate > 1e7)
                fprintf(stderr, "% 5.1f Mb/s", rate / 1048576.0);
            else if (rate > 1e4)
                fprintf(stderr, "% 5.1f Kb/s", rate / 1024.0);
            else
                fprintf(stderr, "% 5.1f b/s", rate);
    
            fprintf(stderr, "     \r");
        }
    
        free(buf);
    }
    
    int main(int argc, char **argv) {
        char *s = getenv("COLUMNS");
        int i;
        if (s && (i = atoi(s)) && i > 0) columns = i;
    
        signal(SIGPIPE, SIG_IGN); /* We would rather get an EPIPE return. */
    
        /* FIXME should we reopen stderr as /dev/tty if !isatty(2)? */
    
        /* Copy stdin to stdout. */
        if (argc == 1)
            pipe_copy_progress("standard input", 0, 1);
        else if (argc == 2 &&
                 (!strcmp(argv[1], "--help") || !strcmp(argv[1], "-h"))) {
            fprintf(stderr,
    "cwp: catenate with progress\n"
    "%s\n"
    "\n"
    "   cwp file ...\n"
    "       catenate the given files on standard output, giving a\n"
    "       progress indication for each file on standard error\n"
    "\n"
    "   cwp\n"
    "       copy standard input to standard output, giving a\n"
    "       progress indication on standard error\n"
    "\n"
    "Copyright (c) 2001 Chris Lightfoot <chris@ex-parrot.com>. Redistribute freely.\n",
            rcsid);
        } else {
            char **a;
            for (a = argv + 1; *a; ++a) {
                struct stat st;
                stat(*a, &st);
                if (S_ISREG(st.st_mode)) {
                    file_copy_progress(*a, 1, st.st_size);
                    fprintf(stderr, "\n");
                } else {
                    int fd;
                    fd = open(*a, O_RDONLY);
                    if (fd == -1) perror(*a);
                    else pipe_copy_progress(*a, fd, 1);
                }
            }
        }
    }
    
    Limoto avatar 4.3.2010 16:10 Limoto | skóre: 32 | blog: Limotův blog
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    copy standard input to standard output, giving a progress indication on standard error
    Přesně tohle dělá pv...
    4.3.2010 18:28 xurfa
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    Taktak, pv je výtečné pro různé skriptíky...
    4.3.2010 21:28 d.c. | skóre: 30
    Rozbalit Rozbalit vše Re: Progress bar pro příkaz cp
    Jeden známý mi kdysi vysvětloval, že podstatná část vývoje programování ve woknech spočívá ve vylepšování teploměrů a odhadů, jak mají běhat. Jestli se tahle věda jednou dostane do Linuxu, jdu od válu. :o)

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.