ATOUTFOX
COMMUNAUTÉ FRANCOPHONE DES PROFESSIONNELS FOXPRO
Visual FoxPro : le développement durable

Affiliation RSS   

rss RSS : Really Simple Syndication

Le format RSS (fichier XML) permet de syndiquer du contenu provenant d'autres sites.
www.atoutfox.org propose :

  • la publication d'un flux RSS des dernières contributions du site www.atoutfox.org
  • la publication d'un flux RSS des derniers messages sur le forum www.atoutfox.org
  • de consulter les fluxs RSS relatant de Visual FoxPro provenant d'autres sites.

Pour répondre aux questions reçues suite à l'ouverture de cette rubrique :
« c'est quoi un RSS ? »  et  « à quoi cela sert-il ? »
Une  réponse résumée et très simplifiée :
Un feed RSS est un fichier créé dynamiquement, au format XML, contenant : une date de publication, un titre, un auteur, éventuellement une description (ou partie de description), et un lien.
Dans le cas d'Atoutfox, le feed RSS est une publication des entêtes des contributions.
Ce feed RSS rendu public permet d'être utilisé dans un autre site : la liste du contenu du site source apparait dynamiquement dans le contenu du site client avec un lien retournant sur la source... (Syndication). Le site client augmente son contenu, le site source reçoit des liens et augmente sa visibilité et son référencement.
Les informations sont à jours sur tous les sites en même temps puisque c'est dynamique.
Exemple d'utilisation d'un flux RSS : affichage ci-après des 6 derniers codes et forum de www.foxprofr.com à l'intérieur de www.atoutfox.org... Est-ce plus clair ? (sinon un petit appel à votre ami google... ;-)

Cordialement, Francis FAURE

 

Les 6 derniers articles de...

Feed RSS des dernières contributions ajoutées sur www.atoutfox.org    (source )

Date Titre Auteur
21/04/2017
09:56:57

DBF -> MsExcel 2007+
Bugs corrigés
- erreur sous Windows XP causée par l'appel de htmspec() dans getccur() (avec la permission de Martina Jindrová)
- lentgh of index for memos (avec la permission de Tobias B)
- propriété "label" peut être une string ( avec la permission de Tobias B)

Vilhelm-Ion Praisach
11/01/2017
09:56:57

DBF -> MsOffice (VFP9 version 4, VFP6 version 2/3)
Fonction et classes pour Export DBF -> MsOffice
Versions pour VFP9 et VFP6 (janvier 2017).

Vilhelm-Ion Praisach
04/12/2016
09:56:57

Ajout de logo dans une feuille Excel
On trouve un peu partout dans le WEB la méthode, Insert_Image() , pour insérer une image ou un logo dans une feuille Excel.
.
Cette méthode présente l'inconvénient de ne pas conserver l'image ou le logo après sauvegarde de la feuille Excel dans certaines situations.
.
La méthode suivante, Add_Image() , permet de conserver image ou logo après la sauvegarde de la feuille.

FAUCONNET MIchel
26/11/2016
09:56:57

Version 3.1415926 du décompilateur DVFP
Version 3.1415926 du décompilateur dvfp Je met à la disposition de la communauté cette version qui bénéficie d'améliorations apportées suites à différents bugs qui m'ont été signalés ces derniers mois.

Pour bien faire je devrais faire une liste des bugs corrigés, mais faute de temps, il est quand même préférable de publier la version plutot que d'attendre que je rédige la doc.

On trouvera, bien sûr, tous les sources dans le zip.

Robert Plagnard

Robert Plagnard
26/11/2016
09:56:57

Report dans les DLL
Report dans les DLL Introduction Le problème initial est la production dynamique de rapports VFP au format PDF pour être téléchargeables sur un site internet.
Le site tourne sous Windows Server, avec IIS et PHP. PHP permet d'instancier un objet COM+ à partir d'une DLL créée en VFP 9. Cet article traite des problèmes rencontrés avec l'instruction « report » dans les DLL VFP9
Dans tout ce qui suit, je considère des rapports qui fonctionnent parfaitement bien quand ils sont lancés dans le contexte d'un EXE. Dans le contexte d'une DLL c'est l'objet de cet article !

Dans une DLL Multi threads Il n'est pas possible d'utiliser l'instruction « report »
Report form MyReport noconsole to file MonFichier.ps nodialog Pas d'erreur à la compilation, mais à l'exécution erreur 1001 : Feature is not available
C'est une erreur générée par le runtime car le code VFP est exactement le même, que l'on compile un EXE, une DLL mono ou une DLL multi threads.

Dans une DLL Mono thread En prenant des précautions dues au contexte mono thread, on peut, dans certaines conditions, utiliser « report ».

Avec « reportbehavior 80 »
Cela n'est pas possible. Même en prenant les précautions pour ne pas écrire dans une interface utilisateur, par exemple :
Set reportbehavior 80 Report form MyReport noconsole to file MonFichier.ps nodialog Génère l' erreur 2031 : User-interface operation not allowed at this time
Alors que dans un EXE, cela marche sans problème. Le fichier.ps est un fichier PostScript que l'on peut visualiser avec gsView par exemple.

Avec « reportbehavior 90 »
Cela dépend.

Set reportbehavior 90 Report form MyReport noconsole to file MonFichier.ps nodialog
Génère l' erreur 1733 : Class definition OUTPUT type 0 is not found
Il semblerait qu'ils aient oublié le cas « to file », et que seuls « to print » et « preview » aient été prévus.

Par contre
Set reportbehavior 90 Report form MyReport noconsole to print nodialog
Fonctionne bien avec une « imprimante pdf ». Personnellement j'utilise « Bullzip PDF printer » qui me donne satisfaction. Extraordinaire ! Sauf que, dès que l'on met une image dans le report (aussi petite soit-elle), on récupère une erreur 1108 : Picture too big, corrupt, or in wrong format C'est un problème lié à l'utilisation de GDI+. Des problèmes analogues ont été décrits par Calvin Hsia (voir http://blogs.msdn.com/b/calvin_hsia/archive/2005/07/24/442873.aspx )
Mais je ne pense pas que ce soit tout à fait la même raison, car on a le même problème que ce soit un JPG, un PNG ou un BMP.
Le problème n'apparait pas de manière systématique, dans un tout petit report, avec la même image, ça marche. Pour produire l'erreur il faut que le rapport soit assez compliqué.
Par contre si l'on met le BMP dans un champ général d'une table, cela marche, c'est un contournement possible. C'est d'ailleurs la seule solution que j'ai trouvée.
Toutes ces raisons m'ont fait essayer xFrx.

Avec XFRX Les difficultés rencontrées sont les suivantes :

Avec le mode classique (sans utiliser les nouvelles possibilités du report 90)
loSes = XFRX("XFRX#INIT") loSes.SetParams("output.pdf",,.T.,,.T.,,"PDF") loSes.ProcessReport("Rapport.frx") loSes.finalize()
Ça marche à 99.9%
Mon report est assez compliqué, avec beaucoup d'impressions conditionnelles, certains traits horizontaux ne sont pas à leur bonne place. Ce n'est pas très grave, mais ce n'est pas joli. L'image JPG située dans l'entête s'affiche bien.
Un autre avantage, dans ce cas, est la possibilité d'utiliser une DLL Multi threads car aucune instruction report n'est utilisée. Tout est fait par xfrx.

En utilisant les nouvelles possibilités du report 90 (reportbehavior 90)
loLsn = XFRX("XFRX#LISTENER") loLsn.SetParams( "output.pdf",,.T.,,.T.,, "PDF" ) report form rapport.frx object loLsn
On l'a bien compris, cette façon de faire ne peut être utilisée que dans une DLL mono thread. Ça marche bien, les traits horizontaux sont bien positionnés, mais on rencontre le même problème avec les images. Cela n'est pas étonnant, car xFrx sous-traite l'affichage à ReportOutPut.app. Je n'ai pas testé mais je pense que le même contournement doit être possible avec un champ général.

Conclusion La solution que j'avais développée dans le cadre de Windows server 2008 était différente. Je n'avais pas trouvée de solution telle que celle décrite ci-dessus et j'avais choisi de produire le rapport à partir d'un EXE qui était lancé dans la DLL. Le lancement de l'EXE se faisant proprement par un CreateProcess de win32api. En attendant la fin de l'exe et en sérialisant les demandes, cette méthode marchait parfaitement bien.
Sous Windows server 2012, je n'arrive plus à lancer l'exe à partir d'un CreateProcess. C'est un problème de droits. J'ai essayé de beaucoup de manières, sans succès. Je pense que les droits et la sécurité sont plus stricts que sur Windows server 2008. On trouve beaucoup d'articles sur ce sujet.
En désespoir de cause, je pensais développer un spooler de rapport (un EXE VFP), qui dans mon cas, serait relativement simple. Ayant besoin d'un seul rapport défini par quelques paramètres. La DLL pourrait faire une demande de rapport en créant une entrée dans une table. Le spooler regardant périodiquement s'il y a des demandes, les satisfait au fur et à mesure et indique que le rapport est prêt. Le spooler est une sorte de service, mais malheureusement on ne sait pas créer de service en VFP. On contourne la difficulté en faisant démarrer automatiquement une session au démarrage du serveur qui elle-même lance automatiquement notre EXE. LogonExpert (produit payant) permet de le faire.
Jusqu'au moment où j'ai trouvé une solution ...

Postscriptum J'ai passé beaucoup plus de temps à trouver la solution simple, qu'il n'aurait fallu de temps pour développer le Spooler. J'aime les solutions simples, mais ce sont les plus difficiles à trouver.

Robert Plagnard le 2 août 2016

Robert Plagnard
25/09/2016
09:56:57

ODT (Writer) -> TXT
Une fonction simple qui extrait le texte contenu dans un document Writer odt , et crée un fichier txt avec le même nom .

ImportOoWrText 1.0

Vilhelm-Ion Praisach

Feed RSS des derniers messages ajoutés sur forum www.atoutfox.org    (source )

Date Titre Auteur
25/04/2017
09:56:57

Re: Rencontres Lyon 2017
Pour ma part, j'y serai vers 19h, après le boulot. On verra combien nous
sommes sur place le mercredi soir.
JC

Le 23/04/2017 à 11:57, GLS a écrit :
> Bonjour,
>
> Réservations avion + rhoneexpress + hotel effectuées et payées..
> Au 10 au soir vers 18h30..
>
> Cordialement
>
>

Jean-Claude Rivi=c3=a8re
23/04/2017
09:56:57

Re: Rencontres Lyon 2017
Bonjour,

Réservations avion + rhoneexpress + hotel effectuées et payées..
Au 10 au soir vers 18h30..

Cordialement

GLS
03/04/2017
09:56:57

Re: CORTANA.FLL : Une nouvelle librairie très intéressante pour Visual FoxPro
je vieillis 'grave' : je n'ai même pas détecté que samedi était le 1er avril !
Merci Francis de me l'avoir rappelé !!

Bonne journée à tous
Jean à Grenoble

Jean à Grenoble
02/04/2017
09:56:57

Re: Comment détecter si l'application est déjà ouverte ?
Bonjour à tous;

J'ai finalement résolu mon problème et ce grâce au forum AtoutFox, la solution suivante a été vérifiée pour le scénario suivant :

- Utilisation de l'application exclusivement en poste local
- L'ouverture de l'application ne se fait que depuis le poste local
- OS Windows 7

-------- Début du code dans le PRG qui lance l'application --------

&& Préparation de l'environnement comme set default, set ... etc


IF isAppStart() = .T.
messagebox("L'application est déjà en cours d'exécution !",48,"Attention")
CLOSE ALL
USE
QUIT
ENDIF


&& Suite du code pour la poursuite de l'exécution de l'application au cas ou isAppStart serait .F.
.....
....
....
...



&& Et tout en bas

PROCEDURE isAppStart()
Local VAL_RETOUR as Boolean
Local fd as Integer, cAppNameEnCours
m.VAL_RETOUR = .F.
m.cAppNameEnCours = alltr(upper(JUSTSTEM(_VFP.Application.ServerName)))
m.cAPPNAME = "GESTION2"


m.fd = Fcreate("c:\Gestion2\"+lower(m.cAPPNAME)+'.txt')
*Messagebox(m.fd)
IF (m.fd < 0 ) && appli deja lancee, On ne peut pas Ouvrir
m.VAL_RETOUR = .T.
Fclose(fd)
ELSE && On peut lancer
If m.cAPPNAME <> m.cAppNameEnCours
Fclose(fd)
m.VAL_RETOUR = .F.
ENDIF
ENDIF
RETURN m.VAL_RETOUR
ENDPROC

-------- Fin du code dans le PRG qui lance l'application --------

Ici le nom de mon application est "Gestion2" et le répertoire est "c:\Gestion2\"

Voila! J'ai voulu partager ma solution qui a bien marché pour mon cas.

La solution est tirée de la proposition de OlivierH.

Merci à tous.

Cordialement.


phoenixset
02/04/2017
09:56:57

Re: Comment détecter si l'application est déjà ouverte ?
Merci infiniment Gregory.

phoenixset
02/04/2017
09:56:57

Re: CORTANA.FLL : Une nouvelle librairie tr=c3=a8s int=c3=a9ressante pour Visual FoxPro
;) bonne réponse Michel !


Le sam. 01 avril 2017, 22h57 Michel Lévy a écrit :
> Est-ce vraiment à la norme SQL 2017?
>
> j'ai essayé avec "Dessine moi un mouton", et la FLL m'a produit [VFP]SELECT * FROM St.Exupery WHERE titre='Le petit Prince'[/VFP].
> Mais à l'exécution j'ai eu une erreur 123456 "Type Geography non compatible avec le système solaire"
>



Francis Faure

Feed RSS des derniers codes ajoutés sur www.foxprofr.com    (source )

Date Titre Auteur

Feed RSS du forum www.foxprofr.com    (source )

Date Titre Auteur

Feed RSS des news de www.foxcentral.net    (source )

Date Titre Auteur
11/04/2017
01:08:13

Southwest Xbase++ 2017 - Cancelled

Southwest Fox Conference
22/03/2017
09:33:55

West Wind Client Tools 6.10 released

West Wind Technologies
20/03/2017
19:22:43

Southwest Fox 2017: Session submission deadline extended

Southwest Fox Conference
07/03/2017
21:03:02

Philly VFUG meets March 14: Tour of Smooth-On, a chemical manufacturing facility automated with VFP

Philadelphia Visual FoxPro User Group
27/02/2017
18:27:04

Southwest Fox/Xbase++ 2017: Call for Speakers

Southwest Fox Conference
22/02/2017
21:03:13

Markdown Monster 1.2 released

West Wind Technologies

Feed RSS de fox.wikis.com    (source )

Date Titre Auteur

 


Publicité

Les pubs en cours :


www.atoutfox.org - Site de la Communauté Francophone des Professionnels FoxPro - v3.4.0 - © 2004-2017.
Cette page est générée par un composant COM+ développé en Visual FoxPro 9.0