Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!

Ogłoszenie

Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.

#1  2014-06-23 02:03:24

  pmiras - Użytkownik

pmiras
Użytkownik
Zarejestrowany: 2014-06-23

Jak uzyskać informację o utworzeniu pliku na dysku

Program, nazwijmy go X, wykonując jakąś operację tworzy w określonej lokalizacji na dysku tekstowe pliki tymczasowe,
które po zakończeniu operacji są usuwane. Chciałbym zautomatyzować proces kopiowania tych plików w inne miejsce.
Jednym słowem: plik pojawia się na dysku i natychmiast ma być automatycznie kopiowany do innej lokalizacji.
Nie mam żadnych możliwości zrobić tego z poziomu programu X.
Czy istnieje jakieś rozwiązanie tego problemu, a jeśli tak, to jak to zrobić ?

Offline

 

#2  2014-06-23 02:34:45

  Jacekalex - Podobno człowiek...;)

Jacekalex
Podobno człowiek...;)
Skąd: /dev/urandom
Zarejestrowany: 2008-01-07

Re: Jak uzyskać informację o utworzeniu pliku na dysku

Musisz chyba pokombinować z inotify lub dnotify, tu masz przykład automatycznego dodawania znaków wodnych do pdfów z użyciem [b]inotifywatch[/b]:
http://blog.lagentz.com/general/automate-your-shell-scripts-using-inotify-and-inotifywait/

Możesz się tez pobawić Perlem i modułem  [b]Linux::Inotify2[/b]:
http://blogs.perl.org/users/smash/2010/07/watching-directories-for-new-files.html
http://search.cpan.org/~mlehmann/Linux-Inotify2-1.22/Inotify2.pm

Pozdro
;-)


W demokracji każdy naród ma taką władzę, na jaką zasługuje ;)
Si vis pacem  para bellum  ;)       |       Pozdrawiam :)

Offline

 

#3  2014-06-23 12:15:35

  ethanak - Użytkownik

ethanak
Użytkownik
Skąd: Ungwenor
Zarejestrowany: 2010-07-19
Serwis

Re: Jak uzyskać informację o utworzeniu pliku na dysku

kiedyś się czymś podobnym bawiłem. napisałem bibliotekę z jedną funkcją (odpowiednikiem funkcji  z glibca) która nie robiła nic oprócz radosnego zakończenia z sygnalizacją sukcesu i podpiąłem przez LD_PRELOAD.
może więc napisać własny odpowiednik funkcji unlink?


Nim mechaniczne larum zagrasz mi, kanalio,
głosząc nadejście Javy - śmiertelnego wroga!
[i]Zespół Adwokacki Dyskrecja[/i]

Offline

 

#4  2014-06-23 21:22:41

  pmiras - Użytkownik

pmiras
Użytkownik
Zarejestrowany: 2014-06-23

Re: Jak uzyskać informację o utworzeniu pliku na dysku

[quote=Jacekalex]Musisz chyba pokombinować z inotify lub dnotify, tu masz przykład automatycznego dodawania znaków wodnych do pdfów z użyciem [b]inotifywatch[/b]:
http://blog.lagentz.com/general/automate-your-shell-scripts-using-inotify-and-inotifywait/

Możesz się tez pobawić Perlem i modułem  [b]Linux::Inotify2[/b]:
http://blogs.perl.org/users/smash/2010/07/watching-directories-for-new-files.html
http://search.cpan.org/~mlehmann/Linux-Inotify2-1.22/Inotify2.pm

Pozdro
;-)[/quote]
Serdeczne dzięki za wskazanie właściwego kierunku, to będzie to. Mam teraz kupę
materiału do przestudiowania bo polecenie inotifywait może mieć wiele ciekawych
i różnych zastosowań.

Pozdrawiam.

Offline

 

Stopka forum

Powered by PunBB
© Copyright 2002–2005 Rickard Andersson
Nas ludzie lubią po prostu, a nie klikając w przyciski ;-)

[ Generated in 0.007 seconds, 11 queries executed ]

Informacje debugowania

Time (s) Query
0.00011 SET CHARSET latin2
0.00004 SET NAMES latin2
0.00046 SELECT u.*, g.*, o.logged FROM punbb_users AS u INNER JOIN punbb_groups AS g ON u.group_id=g.g_id LEFT JOIN punbb_online AS o ON o.ident='18.117.71.239' WHERE u.id=1
0.00090 REPLACE INTO punbb_online (user_id, ident, logged) VALUES(1, '18.117.71.239', 1732560080)
0.00046 SELECT * FROM punbb_online WHERE logged<1732559780
0.00044 SELECT topic_id FROM punbb_posts WHERE id=270230
0.00006 SELECT id FROM punbb_posts WHERE topic_id=26034 ORDER BY posted
0.00050 SELECT t.subject, t.closed, t.num_replies, t.sticky, f.id AS forum_id, f.forum_name, f.moderators, fp.post_replies, 0 FROM punbb_topics AS t INNER JOIN punbb_forums AS f ON f.id=t.forum_id LEFT JOIN punbb_forum_perms AS fp ON (fp.forum_id=f.id AND fp.group_id=3) WHERE (fp.read_forum IS NULL OR fp.read_forum=1) AND t.id=26034 AND t.moved_to IS NULL
0.00007 SELECT search_for, replace_with FROM punbb_censoring
0.00109 SELECT u.email, u.title, u.url, u.location, u.use_avatar, u.signature, u.email_setting, u.num_posts, u.registered, u.admin_note, p.id, p.poster AS username, p.poster_id, p.poster_ip, p.poster_email, p.message, p.hide_smilies, p.posted, p.edited, p.edited_by, g.g_id, g.g_user_title, o.user_id AS is_online FROM punbb_posts AS p INNER JOIN punbb_users AS u ON u.id=p.poster_id INNER JOIN punbb_groups AS g ON g.g_id=u.group_id LEFT JOIN punbb_online AS o ON (o.user_id=u.id AND o.user_id!=1 AND o.idle=0) WHERE p.topic_id=26034 ORDER BY p.id LIMIT 0,25
0.00088 UPDATE punbb_topics SET num_views=num_views+1 WHERE id=26034
Total query time: 0.00501 s