EPICS Controls Argonne National Laboratory

Experimental Physics and
Industrial Control System

1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  <20072008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  2023  2024  Index 1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  <20072008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  2023  2024 
<== Date ==> <== Thread ==>

Subject: Re: CAJ usage
From: "J. Lewis Muir" <[email protected]>
To: [email protected]
Date: Wed, 09 May 2007 09:32:47 -0400
J. Lewis Muir wrote:
David Dudley wrote:
Ok, getting much closer now.

I switched from blackdown-jdk-1.4.2.03 to sun-jdk-1.5.0.11.  Things are
starting to work better now.

Made the modifications suggested to the build.xml file to remove the
jni interface.  I don't think I can manage any native interface code in
this particular application given the varied machine architectures that
are going to access it.

jca now compiles without error.   After adding the reference to the jca
library in caj, it compiles fine also.

Modified my classpath to include the output .jar files, and now I can
compile the 'SimpleJCAGet.java' program without errors.
I have a data point named 'TotalSystemLoad' which is the total KW used
by the plant, and I can do a camonitor 'TotalSystemLoad' on that
successfully.
However, when I say 'java SimpleJCAGet TotalSystemLoad', I get:
'Exception in thread "main" java.lang.NoClassDefFoundError:
SimpleJCAGet'.
Getting better, I just need to get some decent java training, I guess.

David

It looks like it can't find SimpleJCAGet. SimpleJCAGet needs to be on your classpath too. Where is SimpleJCAGet.class? What package is SimpleJCAGet in (i.e. the package declaration at the top of SimpleJCAGet.java, or the default package if there is no such declaration)?


If SimpleJCAGet is in the default package, then your classpath should include the directory where SimpleJCAGet.class resides. If SimpleJCAGet is in a package, say "com.cctexas", then your classpath should include the directory that contains the com directory (where the SimpleJCAGet.class file is at com/cctexas/SimpleJCAGet.class).

-lewis

Hi, David.


I should have also noted that in the case where SimpleJCAGet is in a package, you will need to refer to it by its fully qualified name when running it from the command line. For example:

$ java com.cctexas.SimpleJCAGet TotalSystemLoad

-lewis

"J. Lewis Muir" <[email protected]> 5/8/2007 3:14 PM >>>
David Dudley wrote:
Well, getting closer.

I had jca-2.3.1 source downloaded earlier.

Moved to directory and did 'ant', it said:

build.core.java:
     [echo] Building core classes
    [javac] Compiling 67 source files to
/usr/local/EPICS/modules/soft/jca/jca-2.3.1/O.core
    [javac]

/usr/local/EPICS/modules/soft/jca/jca-2.3.1/src/core/gov/aps/jca/dbr/DBR_Double.java:89:

cannot resolve symbol
[javac] symbol : method format
(java.util.Locale,java.lang.String,java.lang.Object[])
[javac] location: class java.lang.String
[javac] toValue[i] =
String.format(Locale.US, formatFString, params);
[javac]

^
    [javac]

/usr/local/EPICS/modules/soft/jca/jca-2.3.1/src/core/gov/aps/jca/dbr/DBR_Double.java:93:

cannot resolve symbol
[javac] symbol : method format
(java.util.Locale,java.lang.String,java.lang.Object[])
[javac] location: class java.lang.String
[javac] toValue[i] =
String.format(Locale.US, formatEString, params);
[javac]
       ^
    [javac]

/usr/local/EPICS/modules/soft/jca/jca-2.3.1/src/core/gov/aps/jca/dbr/DBR_Float.java:91:

cannot resolve symbol
[javac] symbol : method format
(java.util.Locale,java.lang.String,java.lang.Object[])
[javac] location: class java.lang.String
[javac] toValue[i] =
String.format(Locale.US, formatFString, params);
[javac]

^
    [javac]

/usr/local/EPICS/modules/soft/jca/jca-2.3.1/src/core/gov/aps/jca/dbr/DBR_Float.java:95:

cannot resolve symbol
[javac] symbol : method format
(java.util.Locale,java.lang.String,java.lang.Object[])
[javac] location: class java.lang.String
[javac] toValue[i] =
String.format(Locale.US, formatEString, params);
[javac]
       ^
    [javac]

/usr/local/EPICS/modules/soft/jca/jca-2.3.1/src/core/gov/aps/jca/jni/JNIContext.java:147:

cannot resolve symbol
    [javac] symbol  : constructor IllegalStateException
(java.lang.String,java.lang.Throwable)
    [javac] location: class java.lang.IllegalStateException
    [javac]       throw new IllegalStateException( "Context not
initialized", th );
    [javac]             ^
    [javac] 5 errors

BUILD FAILED
/usr/local/EPICS/modules/soft/jca/jca-2.3.1/build.xml:144: Compile
failed; see the compiler error output for details.

Total time: 5 seconds

Getting closer, I would say.

So, you're saying that caj only replaces the JNI part of jca with a
java package, instead of the native interface package?

That's correct. Instead of using the EPICS libraries for Channel Access


communication, CAJ implements the Channel Access protocol in Java.

About your build problem. What archive of JCA did you download? When I

downloaded the tar-gz file from http://jca.cosylab.com/ and extracted it, tar said "tar: A lone zero block at 1809". I downloaded the zip
file and it extracted cleanly:


$ curl -O http://jca.cosylab.com/distributions/jca-2.3.1-src.zip
Before building JCA, I set EPICS_BASE_RELEASE (sh shell):

$ export EPICS_BASE_RELEASE=/opt/epics-3.14.8.2/base

If you're planning to use the ant install target, you should set EPICS_EXTENSIONS to an appropriate value also.

Then I was able to do

$ ant clean
$ ant

If you are planning to use only the CAJ Channel Access implementation,

you could consider compiling JCA without the native EPICS libraries. However, I don't know that this is officially supported. I was able to

successfully compile JCA without native EPICS libraries by removing the

build.core.jni target from the depends attribute of the build.core target in build.xml:

---replace this---
<target name="build.core" depends="build.core.java,build.core.jni">
---with this (i.e. remove "build.core.jni" target dependency)---
<target name="build.core" depends="build.core.java">
---

In this case, I just did (sh shell)

$ export EPICS_BASE_RELEASE=''
$ ant clean
$ ant

The JAR file is created at "O.core/jca.jar".

-lewis

Kay-Uwe Kasemir <[email protected]> 5/8/2007 2:24 PM >>>
Hi:

You need jca, which gives you
a) The basic java API, a lot of interfaces, in a jca.jar file.
    That's what ant complains about with the missing gov.aps.jca.
b) A JNI implementation of those interfaces,
    using the CA client lib from EPICS base,
    in some *so or *dll file.

Just jca works fine, but the problem is that it depends on the
JNI implementation, i.e. binary, system-dependent code.
You need to build the JNI part of jca for Win32, Linux, Linux
64-bit,
OSX-on-ppc, OSX-on-intel, for every version of EPICS base that
you want to use.

CAJ provides a pure java implementation, so it replaces (b).
At the SNS, we had some problems with CAJ possibly causing
hangups of CA server threads on IOCs, but the current hope is
that that's been fixed as long as you use the latest jca/caj
and IOCs run R3.14.9.

-Kay


On May 8, 2007, at 15:04 , David Dudley wrote:


I'm trying to configure and use the CAJ library, since I can't be
sure
what kind of machine the application will be used on. It can almost be
guaranteed that whatever machine it is, it won't have EPICS on it,
for
sure.

I downloaded caj-1.1.3-src and caj-1.1.3.tar, and am attempting to
figure out how to use it.

From the caj-1.1.3 source directory, I can't get ant to operate without
giving pages and pages of errors. It looks for package
'gov.aps.jca',
but shows that package does not exist.

Still working on getting use to java, I've been a 'c' programmer
for
around 20 years or so.
All I did was go go to the source directory and type 'ant'.  Was
there
something else I was supposed to do as well?

David

"Matej Sekoranja" <[email protected]> 11/26/2006 1:49 PM

Hi,

sorry for the late reply.

Is there any additional information on utilizing the Jca library
other
than the Tutorial listed? I'd like to use a 'monitor' function to
display
changing data, but there isn't exactly any documentation on it.
There is a series of EPICS training material.
Java and JCA can be found here:
http://www.aps.anl.gov/aod/bcda/epicsgettingstarted/developtools/ java.html


See also CA client library tutorials.

Any help would be appreciated.


The best thing is to look at BasicExample source (found in the sources). I attach it anyway.

Matej
<David Dudley.vcf>






References:
Re: CAJ usage David Dudley
Re: CAJ usage Kay-Uwe Kasemir
Re: CAJ usage David Dudley
Re: CAJ usage J. Lewis Muir
Re: CAJ usage David Dudley
Re: CAJ usage J. Lewis Muir

Navigate by Date:
Prev: Re: EPICS Meeting presentations - online Peter Zumbruch
Next: Re: CAJ usage David Dudley
Index: 1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  <20072008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  2023  2024 
Navigate by Thread:
Prev: Re: CAJ usage J. Lewis Muir
Next: Re: CAJ usage David Dudley
Index: 1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  <20072008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  2023  2024 
ANJ, 10 Nov 2011 Valid HTML 4.01! · Home · News · About · Base · Modules · Extensions · Distributions · Download ·
· Search · EPICS V4 · IRMIS · Talk · Bugs · Documents · Links · Licensing ·