Examples of Translator

  • eas.simulation.spatial.sim2D.marbSimulation.translator.Translator
    Klasse zur Repräsentation eines endlichen Automaten mit Übersetzerfunktion.

    Der Übersetzerautomat kann aus folgenden Zuständen bestehen (p und z sind die beim Zustzand gespeicherten Parameter; der Befehl des Zustands ist als Funktionsname vor die Klammer geschrieben):
    - kno(p): Erzeuge Knoten mit dem Namen, der an Hp steht.
    - bef(p, z): Setze Befehl des Knotens mit dem Namen an Adresse Hp auf den Wert an Adresse Hz.
    - par(p, z): Setze Parameter des Knotens mit dem Namen an Adresse Hp auf den Wert an Adresse Hz.
    - zus(p, z): Setze Zusatzparameter des Knotens mit dem Namen an Adresse Hp auf den Wert an Adresse Hz.
    - KAN(p, z): Füge eine Kante von dem Zustand, der an Adresse Hp steht zu dem Zustand, der an Adresse Hz steht ein; die Kante erhält die Beschriftung, die Vorher durch T-X erzeugt wurde.
    - T-X(p): Erweitere die aktuelle Bedingung um den Wert, der an Hp steht, addiert mit k, wobei gilt:
    k = 0, falls X = 'C',
    k = 255, falls X = 'H',
    k = Konstanten.autTOscript(Hp) - Hp, falls X = 'O' (511, 512: T, F; 513-520: Comp; 521, 522: OP).
    - R-X(p, z): Speichere an Adresse Hp (nicht an Adresse, die in Hp steht!) den Wert k mit:
    k = z, falls X = 'C',
    k = Wert an Adresse Hz, falls X = 'V'.
    - NXT(): Idle-Befehl, der keine Aktion durchführt.
    - ERG(p, z): Ergänze Zustand p mit Namen, der in Hp steht um eine ausgehende Kante nach zum Zustand, der in Hz steht, sodass immer mindestens eine ausgehende Kante von p true ist. Wenn c1, c2, ... die Bedingungen der ausgehenden Kanten
    Nach den Befehlen kno, bef, par, zus, KAN und ERG wird automatisch noch R-V(Hp, H101) und evtl. R-V(Hz, H102) durchgeführt, das heißt, dass in Adresse H101 nach jedem topologischen Befehl der Name des Ursprungsknotens steht; in H102 steht, im Fall, dass z benutzt wurde, der Wert der topologischen Änderung bzw. der Zielknoten der Kante. In allen Fällen, wo R-V(.,.) nicht durchgeführt wird, bleiben die Register erhalten. Insbesondere bleibt Hn mit n > 102 immer erhalten.

    Nach jedem Zustandswechsel wird der Zeiger im Arbeitscode auf das nächste Token verschoben. Der Code gilt als abgearbeitet, wenn die Variable eoc den Wert true annimmt oder kein gültiger Zustand für den Automaten definiert ist (bspw. wenn der Übersetzerautomat gar keine Zustände besitzt).

    Das aktuelle Token ist in Sensor H100 gespeichert.
    Das nächste Token (look ahead) ist in Sensor H99 gespeichert (0 falls eoc).
    Zu beachten ist, dass die Entscheidung, welche Transition aus einem Zustand heraus benutzt wird, getroffen wird, BEVOR der Code-Zeiger verschoben wird; H100 zeigt also zu dem Zeitpunkt noch das Token an, auf dem gerade gearbeitet wurde, H99 das, welches zum Zeitpunkt des nächsten Zustands aktuell sein wird.
    Die Register sind in den Sensoren H101..Hn gespeichert mit n = 100 + #Register (gewöhnlich n = 103).

    ACHTUNG: Um Inkonsistenzen zu vermeiden, sollte auf die Attribute codeZeiger, realSensArray, eoc und boc auch innerhalb der Klasse nicht direkt zugegriffen werden, sondern nur über Getter und Setter (sonst genau überlegen!). @author Lukas König
  • fbench.translate.Translator
  • fmg.fmg8.endlAutomat.translator.Translator
    Klasse zur Repr�sentation eines endlichen Automaten mit �bersetzerfunktion.

    Der �bersetzerautomat kann aus folgenden Zust�nden bestehen (p und z sind die beim Zustzand gespeicherten Parameter; der Befehl des Zustands ist als Funktionsname vor die Klammer geschrieben):
    - kno(p): Erzeuge Knoten mit dem Namen, der an Hp steht.
    - bef(p, z): Setze Befehl des Knotens mit dem Namen an Adresse Hp auf den Wert an Adresse Hz.
    - par(p, z): Setze Parameter des Knotens mit dem Namen an Adresse Hp auf den Wert an Adresse Hz.
    - zus(p, z): Setze Zusatzparameter des Knotens mit dem Namen an Adresse Hp auf den Wert an Adresse Hz.
    - KAN(p, z): F�ge eine Kante von dem Zustand, der an Adresse Hp steht zu dem Zustand, der an Adresse Hz steht ein; die Kante erh�lt die Beschriftung, die Vorher durch T-X erzeugt wurde.
    - T-X(p): Erweitere die aktuelle Bedingung um den Wert, der an Hp steht, addiert mit k, wobei gilt:
    k = 0, falls X = 'C',
    k = 255, falls X = 'H',
    k = Konstanten.autTOscript(Hp) - Hp, falls X = 'O' (511, 512: T, F; 513-520: Comp; 521, 522: OP).
    - R-X(p, z): Speichere an Adresse Hp (nicht an Adresse, die in Hp steht!) den Wert k mit:
    k = z, falls X = 'C',
    k = Wert an Adresse Hz, falls X = 'V'.
    - NXT(): Idle-Befehl, der keine Aktion durchf�hrt.
    - ERG(p, z): Erg�nze Zustand p mit Namen, der in Hp steht um eine ausgehende Kante nach zum Zustand, der in Hz steht, sodass immer mindestens eine ausgehende Kante von p true ist. Wenn c1, c2, ... die Bedingungen der ausgehenden Kanten
    Nach den Befehlen kno, bef, par, zus, KAN und ERG wird automatisch noch R-V(Hp, H101) und evtl. R-V(Hz, H102) durchgef�hrt, das hei�t, dass in Adresse H101 nach jedem topologischen Befehl der Name des Ursprungsknotens steht; in H102 steht, im Fall, dass z benutzt wurde, der Wert der topologischen �nderung bzw. der Zielknoten der Kante. In allen F�llen, wo R-V(.,.) nicht durchgef�hrt wird, bleiben die Register erhalten. Insbesondere bleibt Hn mit n > 102 immer erhalten.

    Nach jedem Zustandswechsel wird der Zeiger im Arbeitscode auf das n�chste Token verschoben. Der Code gilt als abgearbeitet, wenn die Variable eoc den Wert true annimmt oder kein g�ltiger Zustand f�r den Automaten definiert ist (bspw. wenn der �bersetzerautomat gar keine Zust�nde besitzt).

    Das aktuelle Token ist in Sensor H100 gespeichert.
    Das n�chste Token (look ahead) ist in Sensor H99 gespeichert (0 falls eoc).
    Zu beachten ist, dass die Entscheidung, welche Transition aus einem Zustand heraus benutzt wird, getroffen wird, BEVOR der Code-Zeiger verschoben wird; H100 zeigt also zu dem Zeitpunkt noch das Token an, auf dem gerade gearbeitet wurde, H99 das, welches zum Zeitpunkt des n�chsten Zustands aktuell sein wird.
    Die Register sind in den Sensoren H101..Hn gespeichert mit n = 100 + #Register (gew�hnlich n = 103).

    ACHTUNG: Um Inkonsistenzen zu vermeiden, sollte auf die Attribute codeZeiger, realSensArray, eoc und boc auch innerhalb der Klasse nicht direkt zugegriffen werden, sondern nur �ber Getter und Setter (sonst genau �berlegen!). @author Lukas K�nig
  • hirondelle.web4j.ui.translate.Translator
    avapractices.com/Topic208.cjp">avoid ResourceBundle.

    Guidance For Implementing With A Database
    Example of a web application with the following particular requirements (see the example application for further illustration):

    Here is a style of ResultSet that can be used to implement this interface :

    BaseTextLocaleTranslation
    Fish And ChipsenFish And Chips
    Fish And ChipsfrPoisson et Frites
    deleteendelete
    deletefrsupprimer
    add.edit.buttonenAdd/Edit
    add.edit.buttonfrAjouter/Changer

    Only the last two rows use a "coder key". The BaseText column holds either the coder key, or the user-presentable English. The BaseText is the lookup key. The fact that there is repetition of data between the BaseText and English columns is not a real duplication problem, since this is a ResultSet, not a table - the underlying tables will not have such repetition (if designed properly, of course).

    For example, such a ResultSet can be constructed from three underlying tables - BaseText, Locale, and Translation. Translation is a cross-reference table, with foreign keys to both BaseText and Locale. When such a scheme is normalized, it will have no repeated data. (In underlying queries, however, the base language will be necessarily treated differently than the other languages.)

    Upon startup, the tables are read, the above ResultSet is created and stored in a private static Map, represented schematically as Map[BaseText, Map[Locale, Translation]]. When a translation is required, this Map is used as an in-memory lookup table. This avoids repeated fetching from the database of trivial data that rarely changes.

    Note on Thread Safety
    In the suggested implementation style, the private static Map that stores translation data is static, and thus shared by multiple threads. Implementations are free to implement any desired policy regarding thread safety, from relaxed to strict. A relaxed implementation might completely ignore the possibility of a mistaken read/write, since no writes are expected in production, or simply because the consequences are usually trivial. A strict implementation would take the opposite approach, and demand that the private static Map be used in an fully thread-safe manner.

  • nu.fw.jeti.plugins.Translator
    @author E.S. de Boer
  • org.andromda.core.translation.Translator
    Provides expression translation capabilities. Every expression translator must implement this interface. @author Chad Brandon
  • org.apache.fop.render.awt.viewer.Translator
    AWT Viewer's localization class, backed up by java.util.ResourceBundle. Originally contributed by: Stanislav.Gorkhover@jCatalog.com
  • org.apache.fop.viewer.Translator
    Definition f�r die �bersetzer-Klassen. @version 03.12.99 @author Stanislav.Gorkhover@jCatalog.com
  • org.apache.hivemind.schema.Translator
    Object which can translate a string into an object value. This is used to translate attribute values (or element content) from strings into numbers, booleans or other constructs before assigning the final value to a propery. Translation occurs after symbol substitution.

    Translator classes should have a public constructor that takes no arguments. They may optionally have a second constructor that takes a single string as a parameter. When the {@link org.apache.hivemind.parse.DescriptorParser} encountersa translator of the form "translator-id,initialization-string" (example: "int,min=0") it will use the second constructor, passing the initialization string.

    Generally, initializion strings are of the form key=value[,key=value]*. Each initializer has a set of keys it recognizes, other keys are simply ignored. @author Howard Lewis Ship

  • org.apache.pivot.wtkx.Translator
    Translates WTKX documents into compilable Java file objects.

    NOTE: This class contains experimental functionality and should be considered a "preview" until a future release.

  • org.apache.tapestry.Translator
    Translates between client-side and server-side values. Client-side values are always strings. @param < T>
  • org.apache.tapestry.form.translator.Translator
    Interface used by {@link ValidatableField}s to both format an object as text and translate submitted text into an appropriate object for a given field. @author Paul Ferraro @since 4.0
  • org.apache.tapestry5.Translator
    Translates between client-side and server-side values. Client-side values are always strings. @param < T> @see org.apache.tapestry5.services.TranslatorSource @see org.apache.tapestry5.FieldValidationSupport @see org.apache.tapestry5.FieldTranslator
  • org.apache.tika.language.translate.Translator
    Interface for Translator services. @since Tika 1.6
  • org.eclipse.wst.common.internal.emf.resource.Translator
  • org.fao.geonet.kernel.search.Translator
    Takes a key and looks up a translation for that key. @author jesse
  • org.foray.render.awt.viewer.Translator
    Interface for classes that can translate words from one natural language to another, for purposes of creating a multi-lingual user interface.
  • org.geoscript.geocss.Translator
  • org.geotools.xml.transform.Translator
    A Translator is used in an XMLEncoding process by the FeatureTransformer class. @author Ian Schneider @source $URL$
  • org.jboss.classloading.spi.Translator
    An implementation of this interface in order to transform class files. The transformation occurs before the class is defined by the JVM. @see java.lang.instrument.ClassFileTransformer @author Scott.Stark@jboss.org @version $Revision:$
  • org.jboss.util.loading.Translator
    An interface for transforming byte code before Class creation. This is compatible with the JDK1.5 java.lang.instrument.ClassFileTransformer proposal. @author Scott.Stark@jboss.org @version $Revision: 2787 $
  • org.jbpm.formapi.server.trans.Translator
  • org.jbpm.formbuilder.server.trans.ftl.Translator
  • org.olat.core.gui.translator.Translator
    @author Felix Jost
  • org.omnaest.i18nbinder.internal.facade.I18nFacade.Translator
  • org.openmrs.module.htmlformentry.Translator
    Encapsulates Translator functionality (see {@see HtmlFormEntryGenerator#applyTranslations(String, FormEntryContext)})
  • org.teiid.adminapi.Translator
  • org.zkoss.zuss.impl.out.Translator
    The translator used to translate ZUSS to CSS. @author tomyeh
  • pivot.wtkx.Translator
    Translates WTKX documents into compilable Java file objects.

    NOTE: This class contains experimental functionality and should be considered a "preview" until a future release. @author tvolkert


  • Examples of org.olat.core.gui.translator.Translator

       * @param fallback The fallback translator that should be used
       * @return
       */
      public static Translator createPackageTranslator(Class baseClass, Locale locale, Translator fallback) {
        String transpackage = Util.getPackageName(baseClass);
        Translator trans;
        if(fallback != null) {
          trans = new PackageTranslator(transpackage, locale, fallback);
        } else {
          trans = new PackageTranslator(transpackage, locale);
        }
    View Full Code Here

    Examples of org.olat.core.gui.translator.Translator

      @Override
      public void setTranslator(Translator translator) {
        // wrap package translator with fallback form translator
        // hint: do not take this.getClass() but the real class! for package translator creation
        Translator elmTranslator = Util.createPackageTranslator(TextAreaElementImpl.class, translator.getLocale(), translator);
        super.setTranslator(elmTranslator);
      }
    View Full Code Here

    Examples of org.olat.core.gui.translator.Translator

     
      @Override
      public void setTranslator(Translator translator) {
        // wrap package translator with fallback form translator
        // hint: do not take this.getClass() but the real class! for package translator creation
        Translator elmTranslator = Util.createPackageTranslator(TextElementImpl.class,
            translator.getLocale(), translator);
        super.setTranslator(elmTranslator);
      }
    View Full Code Here

    Examples of org.olat.core.gui.translator.Translator

       */
      public void render(Renderer renderer, StringOutput sb, Component source,
          URLBuilder ubu, Translator translator, RenderResult renderResult,
          String[] args) {
        // Use translator with flexi form elements fallback
        Translator trans = Util.createPackageTranslator(FileElementRenderer.class, translator.getLocale(), translator);
        //
        FileElementComponent fileComp = (FileElementComponent) source;
        FileElementImpl fileElem = fileComp.getFileElementImpl();
        String id = fileComp.getFormDispatchId();
        // Calculate current file name: either from already uploaded file or
        // from initial file or empty
        String fileName = fileElem.getUploadFileName();
        if (fileName == null) {
          // try fallback: default file
          File initialFile = fileElem.getInitialFile();
          if (initialFile != null) {
            fileName = initialFile.getName();
          } else {
            fileName = "";
          }
        }

        // Read-write view
        if (source.isEnabled()) {
          sb.append("<div class='b_fileinput'>")
          // input.Browse is the real filebrowser, but set to be transparent.
          // the div.b_fileinput_fakechooser is layered below the input.Browse and represents the visual GUI.
          // Since input.Browse is layered above div.b_fileinput_fakechooser, all click events to go input.Browse
          // See http://www.quirksmode.org/dom/inputfile.html
          sb.append("<input type='file' onkeydown='return false;' name=\"");
           sb.append(id); // name for form labeling
           sb.append("\" id=\"");
           sb.append(id); // id to make dirty button work
           sb.append("\" class='b_fileinput_realchooser' ");
           // Add on* event handlers
           StringBuilder eventHandlers = FormJSHelper.getRawJSFor(fileElem.getRootForm(), id, fileElem.getAction());
           int onChangePos = eventHandlers.indexOf("onchange=");
           if (onChangePos != -1) {
             // add file upload change handler
             sb.append(eventHandlers.substring(0, onChangePos + 10));
             sb.append("b_handleFileUploadFormChange(this, this.form.fake_").append(id).append(", this.form.upload);");
             sb.append(eventHandlers.substring(onChangePos + 10, eventHandlers.length()));
           } else {
             sb.append(eventHandlers);
             sb.append(" onchange=\"b_handleFileUploadFormChange(this, this.form.fake_").append(id).append(", this.form.upload)\"");
           }
           // Add mime type restriction
           Set<String> mimeTypes = fileElem.getMimeTypeLimitations();
           if (mimeTypes.size() > 0 ) {
             sb.append(" accept=\"");
             Iterator iterator = mimeTypes.iterator();
             while (iterator.hasNext()) {
              String type = (String) iterator.next();
              sb.append(type);
              if (iterator.hasNext()) sb.append(",");
            }
             sb.append("\"");
           }
           // Add pseudo focus marker on fake file chooser button
           sb.append(" onfocus=\"this.form.fake_").append(id).append(".nextSibling.style.border = '1px dotted black';\"");
           sb.append(" onblur=\"this.form.fake_").append(id).append(".nextSibling.style.border = '0';\"");
           // Add select text (hover)
           sb.append(" title=\"").append(StringEscapeUtils.escapeHtml(trans.translate("file.element.select"))).append("\"/>")
          sb.append("<div class='b_fileinput_fakechooser'>")
          // Add the visible but fake input field and a styled faked file chooser button
          sb.append("<input name='fake_").append(id).append("' value=\"").append(StringEscapeUtils.escapeHtml(fileName)).append("\"/>")
          sb.append("<a href='#' class='b_with_small_icon_left b_fileinput_icon'><span>").append(trans.translate("file.element.select")).append("</span></a>")
          // Add Max upload size
          if (fileElem.getMaxUploadSizeKB() != FileElement.UPLOAD_UNLIMITED) {
            String maxUpload = Formatter.roundToString((fileElem.getMaxUploadSizeKB()+0f) / 1024, 1);
            sb.append("<span class='b_fileinput_maxsize'>(").append(trans.translate("file.element.select.maxsize", new String[]{maxUpload})).append(")</span>")
          }
          sb.append("</div></div>")
         
          // Add IE fix to deal with SSL and server timeouts
          // See http://bugs.olat.org/jira/browse/OLAT-1299
    View Full Code Here

    Examples of org.olat.core.gui.translator.Translator

        StringOutput content = new StringOutput();
        renderTextElementPart(content, jsdcc.getTextElementComponent());
       
        //
        String triggerId = "trigger_" + jsdcc.getFormDispatchId();
        Translator sourceTranslator = jsdcc.getElementTranslator();

       
        /*
         * add pop js for date chooser, if componente is enabled
         */
        if (source.isEnabled()) {
         
          //date chooser button
          content.append("<span class=\"b_form_datechooser\" id=\"").append(triggerId).append("\" title=\"").append(StringEscapeUtils.escapeHtml(sourceTranslator.translate("calendar.choose"))).append("\">&nbsp;</span>");
          // date chooser javascript
          content.append("<script type=\"text/javascript\">\n /* <![CDATA[ */ \n").append("Calendar.setup({").append("inputField:\"").append(receiverId).append("\",")
              .append("ifFormat:\"");
          if (jsdcc.getDateChooserDateFormat() == null) {
            // use default format from default locale file
    View Full Code Here

    Examples of org.olat.core.gui.translator.Translator

            if ("BusinessGroup".equals(tokenType)) {
              BusinessGroup bg =BusinessGroupManagerImpl.getInstance().loadBusinessGroup(Long.parseLong(tokenKey), true);
              return bg.getName();
            }
           
            Translator translator = Util.createPackageTranslator(this.getClass(), locale);
            String translated = translator.translate(tokenType);
            if (translated == null || translated.length() > 64) {
              return token;//no translation, translator return an error
            }
            return translated;
          }
    View Full Code Here

    Examples of org.olat.core.gui.translator.Translator

          String key = attrKeys[j];
          // OLAT-5089: use translate(String key, String[] args, boolean fallBackToDefaultLocale) version
          //            of Translator because that's the only one not
          String translated = getTranslator().translate(key, null, Level.OFF);
          if (translated.indexOf(PackageTranslator.NO_TRANSLATION_ERROR_PREFIX) == 0) {
             Translator translator = UserManager.getInstance().getPropertyHandlerTranslator(getTranslator());
             String prefix = "form.name.";
              // OLAT-5089: use translate(String key, String[] args, boolean fallBackToDefaultLocale) version
              //            of Translator because that's the only one not
             translated = translator.translate(prefix + key, null, Level.OFF);
             if (translated.indexOf(PackageTranslator.NO_TRANSLATION_ERROR_PREFIX) == 0) {
               // could not translate this key, use key for non-translated values
               guiTranslatedAttKeys[j] = key;
             } else {
               guiTranslatedAttKeys[j] = translated;
    View Full Code Here

    Examples of org.olat.core.gui.translator.Translator

      private void addAssessmentSwitch(FormItemContainer formLayout, Controller listener) {

        assessSubContainer = (FormItemContainer) FormLayoutContainer.createDefaultFormLayout("assessSubContainer", getTranslator());
        formLayout.add(assessSubContainer);

        Translator translator = getTranslator();

        final String[] assessmentSwitchKeys = new String[] { NODEPASSED_VAL_PASSED, NODEPASSED_VAL_SCORE };
        final String[] assessmentSwitchValues = new String[] { translator.translate("form.easy.assessmentSwitch.passed"),
            translator.translate("form.easy.assessmentSwitch.score") };

        String nodePassedInitVal = validatedCondition.getEasyModeNodePassedId();
        String cutInitStrValue = validatedCondition.getEasyModeCutValue();
        int cutInitValue = 0;
       
        assessmentSwitch = uifactory.addCheckboxesHorizontal("assessmentSwitch", null, formLayout, new String[] { "ison" }, new String[] { translate("form.easy.assessmentSwitch") }, null);
        assessmentSwitch.addActionListener(listener, FormEvent.ONCLICK);
       

        boolean selectedNodeIsInList = false;
        List<String> keysList = new ArrayList<String>();
        List<String> valuesList = new ArrayList<String>();
        if (nodeIdentList.size() > 0) {
          // there are nodes to be selected
          keysList.add(NO_NODE_SELECTED_IDENTIFYER);
          valuesList.add("- " + translator.translate("form.easy.nodePassed.select") + " -");
          for (int i = 0; i < nodeIdentList.size(); i++) {
            CourseNode courseNode = (CourseNode) nodeIdentList.get(i);
            keysList.add(courseNode.getIdent());
            valuesList.add(courseNode.getShortName() + " (Id:" + courseNode.getIdent() + ")");
            if (courseNode.getIdent().equals(nodePassedInitVal)) selectedNodeIsInList = true;
          }
        } else {
          // no nodes to be selected
          keysList.add(NO_NODE_SELECTED_IDENTIFYER);
          valuesList.add("- " + translator.translate("form.easy.nodePassed.noNodes"));
          //disable switch
          assessmentSwitch.setEnabled(false);
        }
        // add dummy value if needed
        if (nodePassedInitVal != null && !selectedNodeIsInList) {
          keysList.add(DELETED_NODE_IDENTIFYER);
          valuesList.add("- " + translator.translate("form.easy.nodePassed.deletedNode") + " -");
        }
        final String[] nodePassedKeys = new String[keysList.size()];
        keysList.toArray(nodePassedKeys);
        final String[] nodePassedValues = new String[valuesList.size()];
        valuesList.toArray(nodePassedValues);
    View Full Code Here

    Examples of org.olat.core.gui.translator.Translator

       */
      public boolean readyToDelete(OLATResourceable res, UserRequest ureq, WindowControl wControl) {
        ReferenceManager refM = ReferenceManager.getInstance();
        String referencesSummary = refM.getReferencesToSummary(res, ureq.getLocale());
        if (referencesSummary != null) {
          Translator translator = new PackageTranslator(PACKAGE, ureq.getLocale());
          wControl.setError(translator.translate("details.delete.error.references",
              new String[] { referencesSummary }));
          return false;
        }
        /*
         * make an archive of the course nodes with valuable data
    View Full Code Here

    Examples of org.olat.core.gui.translator.Translator

       */
      public boolean readyToDelete(OLATResourceable res, UserRequest ureq, WindowControl wControl) {
        ReferenceManager refM = ReferenceManager.getInstance();
        String referencesSummary = refM.getReferencesToSummary(res, ureq.getLocale());
        if (referencesSummary != null) {
          Translator translator = Util.createPackageTranslator(RepositoryManager.class, ureq.getLocale());
          wControl.setError(translator.translate("details.delete.error.references", new String[] { referencesSummary }));
          return false;
        }
        return true;
      }
    View Full Code Here
    TOP
    Copyright © 2018 www.massapi.com. All rights reserved.
    All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.