1*b1cdbd2cSJim Jagielski/************************************************************** 2*b1cdbd2cSJim Jagielski * 3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one 4*b1cdbd2cSJim Jagielski * or more contributor license agreements. See the NOTICE file 5*b1cdbd2cSJim Jagielski * distributed with this work for additional information 6*b1cdbd2cSJim Jagielski * regarding copyright ownership. The ASF licenses this file 7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the 8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance 9*b1cdbd2cSJim Jagielski * with the License. You may obtain a copy of the License at 10*b1cdbd2cSJim Jagielski * 11*b1cdbd2cSJim Jagielski * http://www.apache.org/licenses/LICENSE-2.0 12*b1cdbd2cSJim Jagielski * 13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing, 14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an 15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*b1cdbd2cSJim Jagielski * KIND, either express or implied. See the License for the 17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations 18*b1cdbd2cSJim Jagielski * under the License. 19*b1cdbd2cSJim Jagielski * 20*b1cdbd2cSJim Jagielski *************************************************************/ 21*b1cdbd2cSJim Jagielski 22*b1cdbd2cSJim Jagielski 23*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_util_XStringEscape_idl__ 24*b1cdbd2cSJim Jagielski#define __com_sun_star_util_XStringEscape_idl__ 25*b1cdbd2cSJim Jagielski 26*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_uno_XInterface_idl__ 27*b1cdbd2cSJim Jagielski#include <com/sun/star/uno/XInterface.idl> 28*b1cdbd2cSJim Jagielski#endif 29*b1cdbd2cSJim Jagielski 30*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_lang_IllegalArgumentException_idl__ 31*b1cdbd2cSJim Jagielski#include <com/sun/star/lang/IllegalArgumentException.idl> 32*b1cdbd2cSJim Jagielski#endif 33*b1cdbd2cSJim Jagielski 34*b1cdbd2cSJim Jagielski//============================================================================= 35*b1cdbd2cSJim Jagielski 36*b1cdbd2cSJim Jagielskimodule com { module sun { module star { module util { 37*b1cdbd2cSJim Jagielski 38*b1cdbd2cSJim Jagielski/** This interface is used to encode an arbitrary String into a 39*b1cdbd2cSJim Jagielski escaped form. 40*b1cdbd2cSJim Jagielski 41*b1cdbd2cSJim Jagielski <p>The escaped form is chosen to be suitable for use with other interfaces 42*b1cdbd2cSJim Jagielski of the object or service providing this interface.</p> 43*b1cdbd2cSJim Jagielski 44*b1cdbd2cSJim Jagielski <p>Any characters or character sequences that are not compatible with 45*b1cdbd2cSJim Jagielski any naming rules or restrictions must be replaced by an escaped form, 46*b1cdbd2cSJim Jagielski that complies to these rules. 47*b1cdbd2cSJim Jagielski 48*b1cdbd2cSJim Jagielski <p>The transformation should preserve all traits of the string that are 49*b1cdbd2cSJim Jagielski generally respected by the service. For example, the case of a string 50*b1cdbd2cSJim Jagielski may be lost after encoding and then decoding, if the service 51*b1cdbd2cSJim Jagielski generally is case insensitive. 52*b1cdbd2cSJim Jagielski 53*b1cdbd2cSJim Jagielski <p>Other than that the encoding is one-to-one and can be reversed. The 54*b1cdbd2cSJim Jagielski encoding should try to preserve as much as possible of the original 55*b1cdbd2cSJim Jagielski string, to keep human-readable input human-friendly where possible. 56*b1cdbd2cSJim Jagielski Strings that already conform to the naming conventions should be left 57*b1cdbd2cSJim Jagielski unchanged or minimally modified.</p> 58*b1cdbd2cSJim Jagielski */ 59*b1cdbd2cSJim Jagielskipublished interface XStringEscape: com::sun::star::uno::XInterface 60*b1cdbd2cSJim Jagielski{ 61*b1cdbd2cSJim Jagielski /** encodes an arbitrary string into an escaped form compatible with some naming rules. 62*b1cdbd2cSJim Jagielski */ 63*b1cdbd2cSJim Jagielski string escapeString([in] string aString) 64*b1cdbd2cSJim Jagielski raises( com::sun::star::lang::IllegalArgumentException); 65*b1cdbd2cSJim Jagielski 66*b1cdbd2cSJim Jagielski /** decodes an escaped string into the original form. 67*b1cdbd2cSJim Jagielski */ 68*b1cdbd2cSJim Jagielski string unescapeString([in] string aEscapedString) 69*b1cdbd2cSJim Jagielski raises( com::sun::star::lang::IllegalArgumentException); 70*b1cdbd2cSJim Jagielski}; 71*b1cdbd2cSJim Jagielski 72*b1cdbd2cSJim Jagielski 73*b1cdbd2cSJim Jagielski//============================================================================= 74*b1cdbd2cSJim Jagielski 75*b1cdbd2cSJim Jagielski}; }; }; }; 76*b1cdbd2cSJim Jagielski 77*b1cdbd2cSJim Jagielski#endif 78*b1cdbd2cSJim Jagielski 79*b1cdbd2cSJim Jagielski 80